Python 3 - Modules

Un module vous permet d'organiser logiquement votre code Python. Le regroupement du code associé dans un module facilite la compréhension et l'utilisation du code. Un module est un objet Python avec des attributs nommés arbitrairement que vous pouvez lier et référencer.

Simplement, un module est un fichier composé de code Python. Un module peut définir des fonctions, des classes et des variables. Un module peut également inclure du code exécutable.

Exemple

Le code Python d'un module nommé aname réside normalement dans un fichier nomméaname.py. Voici un exemple de module simple, support.py -

def print_func( par ):
   print "Hello : ", par
   return

La déclaration d'importation

Vous pouvez utiliser n'importe quel fichier source Python comme module en exécutant une instruction d'importation dans un autre fichier source Python. leimport a la syntaxe suivante -

import module1[, module2[,... moduleN]

Lorsque l'interpréteur rencontre une instruction d'importation, il importe le module si le module est présent dans le chemin de recherche. Un chemin de recherche est une liste de répertoires que l'interpréteur recherche avant d'importer un module. Par exemple, pour importer le module hello.py, vous devez mettre la commande suivante en haut du script -

#!/usr/bin/python3

# Import module support
import support

# Now you can call defined function that module as follows
support.print_func("Zara")

Lorsque le code ci-dessus est exécuté, il produit le résultat suivant -

Hello : Zara

Un module n'est chargé qu'une seule fois, quel que soit le nombre de fois où il est importé. Cela empêche l'exécution du module de se produire à plusieurs reprises, si plusieurs importations se produisent.

La déclaration from ... import

Python fromL'instruction vous permet d'importer des attributs spécifiques d'un module dans l'espace de noms actuel. lefrom...import a la syntaxe suivante -

from modname import name1[, name2[, ... nameN]]

Par exemple, pour importer la fonction fibonacci depuis le module fib, utilisez l'instruction suivante -

#!/usr/bin/python3

# Fibonacci numbers module

def fib(n): # return Fibonacci series up to n
   result = []
   a, b = 0, 1
   while b < n:
      result.append(b)
      a, b = b, a + b
   return result
>>> from fib import fib
>>> fib(100)
[1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89]

Cette instruction n'importe pas le module fib entier dans l'espace de noms courant; il introduit simplement l'item fibonacci du module fib dans la table de symboles globale du module d'importation.

La déclaration from ... import *

Il est également possible d'importer tous les noms d'un module dans l'espace de noms courant en utilisant l'instruction d'importation suivante -

from modname import *

Cela fournit un moyen facile d'importer tous les éléments d'un module dans l'espace de noms actuel; cependant, cette déclaration doit être utilisée avec parcimonie.

Exécution de modules en tant que scripts

Dans un module, le nom du module (sous forme de chaîne) est disponible comme valeur de la variable globale __name__. Le code du module sera exécuté, comme si vous l'aviez importé, mais avec le __name__ mis à "__main__".

Ajoutez ce code à la fin de votre module -

#!/usr/bin/python3

# Fibonacci numbers module

def fib(n): # return Fibonacci series up to n
   result = []
   a, b = 0, 1
   while b < n:
      result.append(b)
      a, b = b, a + b
   return result
if __name__ == "__main__":
   f = fib(100)
   print(f)

Lorsque vous exécutez le code ci-dessus, la sortie suivante s'affiche.

[1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89]

Localisation des modules

Lorsque vous importez un module, l'interpréteur Python recherche le module dans les séquences suivantes -

  • Le répertoire actuel.

  • Si le module n'est pas trouvé, Python recherche alors chaque répertoire dans la variable shell PYTHONPATH.

  • Si tout le reste échoue, Python vérifie le chemin par défaut. Sous UNIX, ce chemin par défaut est normalement / usr / local / lib / python3 /.

Le chemin de recherche du module est stocké dans le module système sys en tant que sys.pathvariable. La variable sys.path contient le répertoire actuel, PYTHONPATH, et la valeur par défaut dépendante de l'installation.

La variable PYTHONPATH

Le PYTHONPATH est une variable d'environnement, constituée d'une liste de répertoires. La syntaxe de PYTHONPATH est la même que celle de la variable shell PATH.

Voici un PYTHONPATH typique d'un système Windows -

set PYTHONPATH = c:\python34\lib;

Et voici un PYTHONPATH typique d'un système UNIX -

set PYTHONPATH = /usr/local/lib/python

Espaces de noms et portée

Les variables sont des noms (identificateurs) qui correspondent aux objets. Un espace de noms est un dictionnaire de noms de variables (clés) et de leurs objets correspondants (valeurs).

  • Une instruction Python peut accéder aux variables dans un espace de noms local et dans l' espace de noms global . Si une variable locale et une variable globale ont le même nom, la variable locale masque la variable globale.

  • Chaque fonction a son propre espace de noms local. Les méthodes de classe suivent la même règle de portée que les fonctions ordinaires.

  • Python fait des suppositions éclairées sur le fait que les variables sont locales ou globales. Il suppose que toute variable affectée d'une valeur dans une fonction est locale.

  • Par conséquent, pour affecter une valeur à une variable globale dans une fonction, vous devez d'abord utiliser l'instruction globale.

  • L'instruction global VarName indique à Python que VarName est une variable globale. Python arrête de rechercher la variable dans l'espace de noms local.

Par exemple, nous définissons une variable Money dans l'espace de noms global. Dans la fonction Money, nous attribuons une valeur à Money, par conséquent Python suppose Money comme variable locale.

Cependant, nous avons accédé à la valeur de la variable locale Money avant de la définir, donc un UnboundLocalError est le résultat. La suppression des commentaires de la déclaration globale résout le problème.

#!/usr/bin/python3

Money = 2000
def AddMoney():
   # Uncomment the following line to fix the code:
   # global Money
   Money = Money + 1

print (Money)
AddMoney()
print (Money)

La fonction dir ()

La fonction intégrée dir () renvoie une liste triée de chaînes contenant les noms définis par un module.

La liste contient les noms de tous les modules, variables et fonctions définis dans un module. Voici un exemple simple -

#!/usr/bin/python3

# Import built-in module math
import math

content = dir(math)
print (content)

Lorsque le code ci-dessus est exécuté, il produit le résultat suivant -

['__doc__', '__file__', '__name__', 'acos', 'asin', 'atan', 
'atan2', 'ceil', 'cos', 'cosh', 'degrees', 'e', 'exp', 
'fabs', 'floor', 'fmod', 'frexp', 'hypot', 'ldexp', 'log',
'log10', 'modf', 'pi', 'pow', 'radians', 'sin', 'sinh', 
'sqrt', 'tan', 'tanh']

Ici, la variable de chaîne spéciale __name__ est le nom du module et __file__ est le nom de fichier à partir duquel le module a été chargé.

Les fonctions globals () et locales ()

le globals() et locals() Les fonctions peuvent être utilisées pour renvoyer les noms dans les espaces de noms global et local en fonction de l'emplacement d'où ils sont appelés.

  • Si locals() est appelée depuis une fonction, elle retournera tous les noms accessibles localement depuis cette fonction.

  • Si globals() est appelée à partir d'une fonction, elle retournera tous les noms accessibles globalement depuis cette fonction.

Le type de retour de ces deux fonctions est dictionnaire. Par conséquent, les noms peuvent être extraits à l'aide dukeys() fonction.

La fonction reload ()

Lorsqu'un module est importé dans un script, le code de la partie de niveau supérieur d'un module n'est exécuté qu'une seule fois.

Par conséquent, si vous souhaitez réexécuter le code de niveau supérieur dans un module, vous pouvez utiliser la fonction reload () . La fonction reload () importe à nouveau un module précédemment importé. La syntaxe de la fonction reload () est la suivante -

reload(module_name)

Ici, nom_module est le nom du module que vous souhaitez recharger et non la chaîne contenant le nom du module. Par exemple, pour recharger le module hello, procédez comme suit -

reload(hello)

Paquets en Python

Un package est une structure de répertoires de fichiers hiérarchique qui définit un environnement d'application Python unique composé de modules et de sous-packages et de sous-sous-packages, etc.

Considérez un fichier Pots.py disponible dans l'annuaire téléphonique. Ce fichier a la ligne suivante de code source -

#!/usr/bin/python3

def Pots():
print ("I'm Pots Phone")

Similaire, nous avons deux autres fichiers ayant des fonctions différentes avec le même nom que ci-dessus. Ils sont -

  • Fichier Phone / Isdn.py ayant la fonction Isdn ()

  • Téléphone / fichier G3.py ayant la fonction G3 ()

Maintenant, créez un autre fichier __init__.py dans le répertoire du téléphone -

  • Phone/__init__.py

Pour rendre toutes vos fonctions disponibles lorsque vous avez importé Phone, vous devez mettre des instructions d'importation explicites dans __init__.py comme suit -

from Pots import Pots
from Isdn import Isdn
from G3 import G3

Après avoir ajouté ces lignes à __init__.py, toutes ces classes sont disponibles lorsque vous importez le package Phone.

#!/usr/bin/python3

# Now import your Phone Package.
import Phone

Phone.Pots()
Phone.Isdn()
Phone.G3()

Lorsque le code ci-dessus est exécuté, il produit le résultat suivant -

I'm Pots Phone
I'm 3G Phone
I'm ISDN Phone

Dans l'exemple ci-dessus, nous avons pris l'exemple d'une seule fonction dans chaque fichier, mais vous pouvez conserver plusieurs fonctions dans vos fichiers. Vous pouvez également définir différentes classes Python dans ces fichiers, puis créer vos packages à partir de ces classes.