Python/L'interpréteur
Il existe deux manières de coder en Python. La première, la plus classique pour ceux qui ont déjà travaillé avec d'autres langages de programmation, est d'écrire des fichiers de code source (dont l'extension est .py), puis d'exécuter ces fichiers, à la manière du Perl.
La seconde, qui est abordée dans ce cours, est d’utiliser l'interpréteur.
Pré-requis
modifierIl faut tout d’abord vérifier que Python est installé sur votre machine, et l'installer dans le cas contraire.
Python 2.3 est pré-installé depuis Mac OS X 10.3 Panther. Pour bénéficier des nouveautés du langage, il est nécessaire de mettre à jour Python. Pour cela, il faut se rendre sur la page de téléchargements de Python et télécharger l'exécutable Mac. L'assistant d'installation s'occupera du reste.
Python 3 peut être installé de trois manières :
- Utiliser un gestionnaire de paquet pour Mac OS X, comme Homebrew.
- Compiler à partir des sources.
- Télécharger l'installateur sur la page de téléchargements de Python.
Python est généralement pré-installé sur les distributions grand public. Pour vérifier que Python est bien installé, il suffit de lancer dans un terminal :
$ python -V # V majuscule
Cette commande vous donnera le numéro de version du Python installé, ou une erreur s'il n’est pas installé.
Dans une distribution basée sur Debian comme Ubuntu, il suffit d'installer les paquets avec le gestionnaire de paquets apt :
$ sudo apt-get update # Mise à jour des dépôts
$ sudo apt-get install python # Installation de la dernière version de Python stable
Si votre distribution ne possède pas de paquets Python, ou si vous désirez effectuer des tests avec une version particulière, il est possible de télécharger Python depuis ses sources. Pour cela, il suffit de se rendre sur https://www.python.org/downloads/source/, puis de suivre les instructions.
Sur Windows, il est nécessaire de télécharger un installeur, comme sur Mac. Rendez-vous sur https://www.python.org/downloads/windows/ pour le trouver.
Si vous n'avez pas les droits administrateurs de votre machine, il existe aussi une version portable.
L'interpréteur
modifierLa version de l'interpréteur est visible au lancement :
En Python 2
$ python
Python 2.5.2 (r252:60911, Jan 24 2010, 14:53:14)
[GCC 4.3.2] on linux2
Type "help", "copyright", "credits" or "license" for more information.
>>>
En Python 3, sous windows
$ python
Python 3.10.0 (tags/v3.10.0:b494f59, Oct 4 2021, 19:00:18) [MSC v.1929 64 bit (AMD64)] on win32
Type "help", "copyright", "credits" or "license" for more information.
>>>
Depuis cette invite de commande, il est possible d'exécuter n’importe quelle instruction Python en tapant cette instruction et en validant grâce à la touche "Entrée" d’un clavier d'ordinateur standard. C’est cet interpréteur qui va être utilisé dans la suite de ce cours.
Dans l’introduction était mentionné la possibilité d'interpréter un code source Python, car des contraintes évidentes de réutilisation du code apparaissent. Pour ce faire, il suffit d'entrer dans une console Unix ou DOS : python nom_du_programme.py
.
Lors de l'exécution d’un programme Python, la machine virtuelle tentera d'opérer à des optimisations en produisant du byte-code dans un fichier d'extension .pyc pour chaque fichier d'extension .py.
Les commandes de base
modifierprint()
modifierAffiche du texte :
>>> print ("Bonjour le monde !")
Bonjour le monde !
>>> print ("texte à répéter, " * 3)
texte à répéter, texte à répéter, texte à répéter,
- Attention : il existe des caractères spéciaux qui ne seront pas affichés :
- \t : tabulation ;
- \n : saut à la ligne (retour chariot) ;
- ...
>>> print("Bonjour \n tout le monde !")
Bonjour
tout le monde !
len()
modifierRenvoie la longueur du paramètre :
>>> len("texte a mesurer")
15
>>>
Les opérateurs
modifierL'interpréteur peut effectuer des actions ne nécessitant pas de mots spécifiques au langage Python, comme de simples opérations mathématiques :
>>> (4+3)*6
42
Cependant les opérateurs suivants ont des sens bien spécifiques :
Opérateur | Rôle | Méthode équivalente |
---|---|---|
# (croisillon) | Introduction d’un commentaire | |
"" (guillemets) ou '' (apostrophes) | Encadrement du texte | |
+ (plus) | Addition, et concaténation de chaînes de caractères | add(), et concat() |
- (moins) | Négation, soustraction | neg(), sub() |
* (étoile) | Multiplication de chiffres, ou wildcard des caractères | mul() |
/ (barre oblique), et // | Division de chiffres | div(), truediv(), et floordiv() |
< | Inférieur à | lt() |
> | Supérieur à | gt() |
<= | Inférieur ou égal à | le() |
>= | Supérieur ou égal à | ge() |
= (égal) | Définition de variable(s) | |
== | Égal à | eq() |
!=, ou <> (chevrons) | Différent de | ne() |
() (parenthèses) | Appel d’une fonction ou méthode | call() |
[] (crochets) | Accès à une liste indexée | getitem(), getslice() |
, (virgule) | Séparation de paramètres | |
. (point) | Virgule décimale, ou séparation des paramètres avec leur méthode | |
** (étoiles) | Puissance (ou exposant) | pow() |
% | Modulo | mod() |
+= | Incrémentation | |
-= | Décrémentation | |
<< | Modification de gauche | lshift() |
>> | Modification de droite | rshift() |
& (et commercial) | Bit à bit "et" | and() |
| (barre verticale) | Bit à bit "ou" | or() |
^ (accent circonflexe) | Bit à bit "ou exclusif" | xor() |
~ (tilde) | Bit à bit "inversion" | invert() |
- L'interpréteur respecte la casse.
- Les espaces (indentation) en début de ligne sont interprétés comme l'inclusion des blocs entre eux. Sauter une ligne fait sortir ces blocs. Cependant, hormis ces cas l'interpréteur n’est pas sensible à la présence d'espace dans le code :
>>> 9/3
3
>>> 9 / 3 # les espaces ne sont pas pris en compte
3
>>> print ("Bonjour le monde!")
Bonjour le monde !
>>> print("Bonjour le monde!")
Bonjour le monde !
>>> x = "Bonjour le monde !"
>>> print (x)
Bonjour le monde !
>>> print x # on peut se passer des parenthèses pour les versions de python inférieures à la 3.0 ; Mais génére une erreur sur les versions supérieures à la 3.0
Bonjour le monde !
>>> printx
Traceback (most recent call last):
File "<interactive input>", line 1, in <module>
NameError: name 'printx' is not defined
- L'interpréteur exécute les instructions en temps réel, dès qu’elles sont validées par l'utilisateur. Ainsi, il n’est pas possible d'exécuter plusieurs blocs d'instructions en une seule fois.
>>> def f(x): # Déclaration d’une fonction
… print 9*x+5
…
>>> f(8)
77
help()
modifierElle permet d'accéder au manuel des commandes Python, ex :
>>> help("dir")
Help on built-in function dir in module __builtin__:
dir(...)
dir([object]) → list of strings
If called without an argument, return the names in the current scope.
Else, return an alphabetized list of names comprising (some of) the attributes
of the given object, and of attributes reachable from it.
If the object supplies a method named __dir__, it will be used; otherwise
the default dir() logic is used and returns:
for a module object: the module's attributes.
for a class object: its attributes, and recursively the attributes
of its bases.
for any other object: its attributes, its class's attributes, and
recursively the attributes of its class's base classes.
>>>
Exemple pour trouver tous les opérateurs et méthodes disponibles avec les nombres décimaux :
>>> help(1.5)
Help on float object:
class float(object)
| float(x) → floating point number
|
| Convert a string or number to a floating point number, if possible.
|
| Methods defined here:
|
| __abs__(...)
| x.__abs__() <==> abs(x)
|
| __add__(...)
| x.__add__(y) <==> x+y
...
dir()
modifierAffiche les méthodes utilisables avec l’objet en argument :
>>> dir("chaine")
['__add__', '__class__', '__contains__', '__delattr__', '__doc__', '__eq__', '__
format__', '__ge__', '__getattribute__', '__getitem__', '__getnewargs__', '__get
slice__', '__gt__', '__hash__', '__init__', '__le__', '__len__', '__lt__', '__mo
d__', '__mul__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__',
'__rmod__', '__rmul__', '__setattr__', '__sizeof__', '__str__', '__subclasshook
__', '_formatter_field_name_split', '_formatter_parser', 'capitalize', 'center',
'count', 'decode', 'encode', 'endswith', 'expandtabs', 'find', 'format', 'index
', 'isalnum', 'isalpha', 'isdigit', 'islower', 'isspace', 'istitle', 'isupper',
'join', 'ljust', 'lower', 'lstrip', 'partition', 'replace', 'rfind', 'rindex', '
rjust', 'rpartition', 'rsplit', 'rstrip', 'split', 'splitlines', 'startswith', '
strip', 'swapcase', 'title', 'translate', 'upper', 'zfill']
On peut donc exécuter toutes ces méthodes avec un texte, ex :
>>> "textes".capitalize() # Met la première lettre en majuscule
'Textes'