Accéder au contenu principal

Découvrez les nouveautés de Python 3.8

Cet article a été publié en tant que thread sur twitter par Elias Walyba, data scientist et machine learner au Sénégal. Néanmoins, j'ai retouché quelques mots.

Python 3.8 est sorti le 14 octobre dernier. Cette nouvelle version de Python vient avec quelques fonctionnalités plutôt intéressantes en terme de développement. Dans ce thread je vous présente quelques unes de ces fonctionnalités que j’ai eu à tester.

1/ L’opérateur de warlus «:=»

Cet opérateur vous permet de faire des assignation de valeurs à des variables dans des expressions ou des blocs d’expressions. Son signe est := . Il est très utile pour éviter de se répéter dans des structures de contrôles.

# Le bout de code suivant (3.7):
if len(dataset) > 1000:
    print(f’’moins de {len(dataset)} éléments attendus’’)

# Devient (3.8):
if (n:=len(dataset)) > 1000:
    print(f’’moins de {n} éléments attendus’’)

2/ Les paramètre «/» et «*» des fonctions

Cette version de Python introduit ce qu’ils appellent: positional-only parameter et qui se note /. Cette fonctionnalités permet de dire que certains paramètres d’une fonction (ou méthode) ne peuvent être passés que par position et pas par clé-valeur. Elle introduit aussi le keywords only parameter qui se note * qui lui permet de dire que certains paramètres ne peuvent être passés que par clé-valeur.

Dans la fonction suivante, a et b ne peuvent être passé que par position, ce qui peut être à la fois passé par position et par clé-valeur et d ne peut être passé que par clé-valeur.

 def func(a, b, /, c, *, e):
    pass

func(2, 5, c=40, e=1.7)

ou

func(2, 5, 40, e=1.7)

Cette fonctionnalité est très utile pour écrire du code avec le paradigme fonctionnel.

3/ Ajout du signe «=» dans les f-strings

L’autre fonctionnalité super sympa de cette version c’est l’ajout du signe = dans les f-strings pour faciliter l’inspection de variable et la self documentation.
La f-string suivante: f"{expr=}" produit la chaine "expr=valeur_de_expr"

Le code suivant:
twitto = "@eliaswalyba"
age = 26
print(f"{twitto=} {age=}")

Produit:
"twitto=@eliaswalyba age=26"

PS: On peut l’utiliser avec les formatages de f-strings pour plus de contrôle.

print(f'{theta=}  {cos(radians(theta))=:.3f}')
theta=30  cos(radians(theta))=0.866

4/ Plus de précision sur le typage

Avec l’introduction de types de données tels que:

  • Literal types
  • Type dictionaries
  • Final objects
  • Protocols


Python prend en charge les indicateurs de type facultatifs, généralement sous forme d'annotations sur le code:

def double(number: float) -> float:
    return 2 * number

Dans cet exemple, number doit être un float et la fonction double() doit également renvoyer un float. Cependant, Python traite ces annotations comme des astuces. Ils ne sont pas appliqués à l'exécution:

double(2)
 retorune 4

double("Dakar)
retourne DakarDakar

Même si cela ne permet pas de faire de Python un langage à typage statique et fort, ça a une réelle importance pour les programmes de type-checking tels que mypy qui pourront l’utiliser pour faire du type-checking avant ou lors de l’édition.

Les types Literal, Protocoles, etc sont accessible via le package typing.

from typing import Literal

5. La fonction reversed() sur les dictionnaires

Depuis Python 3.7, les dictionnaires conservent l'ordre d'insertion des clés.  Avec Python 3.8 reversed() peut maintenant être utilisé pour accéder au dictionnaire dans l'ordre inverse de l'insertion - exactement comme OrderedDict

6. L’unpacking avec return et yield

Depuis Python 3.2, l’unpacking des éléments itérables sans parenthèses dans les instructions return et yield est interdit:

# interdit
def func():
    res = (4, 5, 6)
    return 1, 2, 3, *res

def func():
    res = (4, 5, 6)
    yield 1, 2, 3, *res

Toutes les deux fonctions renvoyaient  des SyntaxError
Avec Python 3.8, ce truc a été corrigé et donc possible maintenant.

7. Syntax Warning

Python 3.8 permet de faire des alertes en cas d’erreurs de syntaxe dans certains cas.

Le code suivant:
data = [
    (1, 2, 3)  # absence de virgule
    (4, 5, 6)
]

Au lieu de générer l’erreur: TypeError: 'tuple' object is not callable qui est une horreur 😱🤯, vous avez maintenant une Syntax Warning qui vous dit que vous avez probablement oublié une virgule. C’est qui est beaucoup mieux pour le débogage.

Voilà c’est tout ce que j’avais à partager avec vous concernant les nouvelles fonctionnalités de Python. Je suis sûr que vous allez les adorer 😍. Pour ma part je ne les trouve pas très nombreuses mais je pense qu’elles sont supers utiles et arrivent au bon moment.

Pour plus de détail vous pouvez consulter la documentation de Python dans la partie Whatsnew ou bien le blog realpython


Merci à Elias Walyba sans qui cet article aurait été beaucoup moins sympa à lire !

Commentaires

Posts les plus consultés de ce blog

Tout savoir sur les modèles et les vues

Hello! Aujourd'hui nous allons passer aux choses sérieuses. Il s'agit ici d'un  article très important qui fera de vous une personne capable de tout modifier sur Odoo.  Oui oui! J'ai bien dit tout modifier car mettez bien dans votre tête qu'avec Odoo on peut tout  faire (Yvan Yelizariev)! Je vous prie de vous concentrer, et de  faire les manipulations que je vais vous montrer! En ce moment, ce que vous allez faire c'est créer un module Odoo puis démarrer votre instance. Ensuite, installez le module point_of_sale et cliquez sur le menu Products. Le reste, on le fera ensemble!

Présentation d'un module Odoo de gestion de bibliothèque: comment développer un tel module?

Hello! Aujourd'hui nous allons continuer notre apprentissage d'Odoo en passant par la phase pratique. Nous allons ensemble développer un module de gestion de bibliothèque et donc le code source sera disponible sur un serveur Git. Le module que nous mettrons en place fera intervenir les modules de gestion de stocks, achats et ventes. Nous implémenterons entre autres des modèles et vues personnalisés, des rapports et des workflows. Bref, ce module vous donnera toutes les techniques et méthodes dont vous aurez besoin pour devenir un développeur Odoo chevronné.

Documentation technique du POS Odoo

Bonjour tout le monde et bienvenue dans la documentation technique du POS Odoo!
Je vais vous proposer ici un ensemble d'articles qui vont permettre d'apprendre à utiliser et personnaliser le module du point de vente sur Odoo. Je souhaite donc savoir concrètement les problèmes que vous rencontrez sur la mise en place du POS afin de vous apporter des réponses pertinentes!
J'attends vos commentaires ci-dessous!