teaching:progappchim:pieges

Différences

Ci-dessous, les différences entre deux révisions de la page.

Lien vers cette vue comparative

Prochaine révision
Révision précédente
Prochaine révisionLes deux révisions suivantes
teaching:progappchim:pieges [2013/10/17 11:42] – créée villersdteaching:progappchim:pieges [2014/07/12 10:24] villersd
Ligne 18: Ligne 18:
   * = pour l'instruction d'affectation et == pour l'opérateur de comparaison   * = pour l'instruction d'affectation et == pour l'opérateur de comparaison
  
-==== l'affectation ne réalise pas une copie =====+===== l'affectation ne réalise pas une copie =====
 Lorsqu'on travaille avec des objets listes (ou d'autres objets), l'instruction utilisant un signe "=" (nom=objet) ne réalise pas une copie, mais donne un second nom au même objet. Si on le manipule (le modifie) en utilisant une des appelations, on peut vérifier l'effet, en tapant les instructions suivantes dans l'interpréteur Python : Lorsqu'on travaille avec des objets listes (ou d'autres objets), l'instruction utilisant un signe "=" (nom=objet) ne réalise pas une copie, mais donne un second nom au même objet. Si on le manipule (le modifie) en utilisant une des appelations, on peut vérifier l'effet, en tapant les instructions suivantes dans l'interpréteur Python :
 <code> <code>
Ligne 40: Ligne 40:
 print v print v
 </code> </code>
 +
 +===== Confusion dans les directives d'importation de librairies =====
 +Il y a 2 façons d'importer toutes les fonctionnalités définies dans un module "nomdemodule" :
 +
 +  * import nomdemodule
 +  * from nomdemodule import *
 +
 +Dans le premier cas, les fonctions seront appelables avec des noms tels que "nomdemodule.func1", tandis que dans le deuxième mode, la même fonction sera utilisable avec le nom "func1". La deuxième méthode permet également de n'importer qu'une seule fonction particulière au lieu de toutes celles qui sont dans le module (avec *). Exemple :
 +
 +  * from nomdemodule import func13
 +
 +Pourquoi 2 façons de faire : l'importation via "from" est simple et permet de s'affranchir de l'écriture du namespace. Cependant, si plusieurs fonctions cohabitent avec des mêmes nom, cela va poser des problèmes car une seule, pas nécessairement "la bonne" sera effective !
 +
 +référence : [[http://effbot.org/zone/import-confusion.htm]]
 +
 +Suggestion : pour comprendre, essayez par exemple ces directives en mode interactif sur le module math.
 +
 +FIXME : intégrer [[http://lignos.org/py_antipatterns/|ces astuces]]
  • teaching/progappchim/pieges.txt
  • Dernière modification : 2016/05/15 22:47
  • de villersd