Aller au contenu

Python/L'interpréteur

Leçons de niveau 14
Une page de Wikiversité, la communauté pédagogique libre.
Début de la boite de navigation du chapitre
L'interpréteur
Icône de la faculté
Chapitre no 1
Leçon : Python
Retour auSommaire
Chap. suiv. :Les types de base
fin de la boite de navigation du chapitre
En raison de limitations techniques, la typographie souhaitable du titre, « Python : L'interpréteur
Python/L'interpréteur
 », n'a pu être restituée correctement ci-dessus.

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.

Il 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

[modifier | modifier le wikicode]

La 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

[modifier | modifier le wikicode]

Affiche 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 !

Renvoie la longueur du paramètre :

>>> len("texte a mesurer")
15
>>>

Les opérateurs

[modifier | modifier le wikicode]

L'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

Elle 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
...

Affiche 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'