Maison > développement back-end > Tutoriel Python > Faites attention à l'explication détaillée des problèmes lors de l'attribution de fonctions aux variables en python

Faites attention à l'explication détaillée des problèmes lors de l'attribution de fonctions aux variables en python

黄舟
Libérer: 2017-08-20 10:50:57
original
2229 Les gens l'ont consulté

L'affectation de variables est un problème que nous rencontrons souvent dans le développement quotidien.L'article suivant vous présente principalement certains problèmes auxquels il faut prêter attention lors de l'attribution de fonctions à des variables en python.L'article le présente à travers un exemple de code. et a une certaine valeur de référence et d'apprentissage pour tous les amis qui en ont besoin peuvent y jeter un œil ci-dessous.

Préface

Cet article vous présente principalement certains problèmes auxquels il faut prêter attention lors de l'attribution de fonctions à des variables en Python. partagez-les avec vous. Étude de référence, pas grand chose à dire ci-dessous, jetons un œil à l'introduction détaillée :

J'ai vu deux formes d'affectation de fonctions à des variables, l'une est


a=f
Copier après la connexion

L'autre est


a=f()
Copier après la connexion

Il y a une différence entre ces deux formes. Résumons-les respectivement. .

1. Le type a=f pointe les variables vers des fonctions.

Vérifiez-le avec le code :


>>> f = abs
>>> f(-10)
10
Copier après la connexion

Explication selon laquelle la variable f pointe désormais vers la fonction abs elle-même. Appeler directement la fonction abs() revient exactement à appeler la variable f(). Ceci est un exemple tiré du didacticiel python du professeur Liao Xuefeng. Maintenant, appeler f() et appeler abs() sont les mêmes.

Un autre exemple de fonction d'usine :


def maker(N):

  def action(X):

    return X**N

  return action
Copier après la connexion

La valeur de retour externe de cette fonction imbriquée est la valeur interne. nom de la fonction Notez qu'il n'y a pas de parenthèses. Il y a une grande différence qu'il y ait des parenthèses ou non. A ce moment, la fonction externe est appelée :


f=maker(2)
Copier après la connexion

Ensuite, comme mentionné ci-dessus, f pointe vers la fonction d'action, et la condition de restriction est N=2, ce qui peut être compris comme f est N La fonction d'action lorsqu'elle est égale à 2. Appelons-le :


>>> f(3)
9
Copier après la connexion

Prouvez que les fonctions f et action sont identiques.

2. Le type a=f() appartient au processus d'attribution de la valeur de retour de f() à un

A ici reçoit uniquement la valeur de retour de f(), si f() n'a pas de valeur de retour, alors a se voit attribuer la valeur Aucune. Une chose à noter ici est que lors de l'exécution de a=f(), f() s'exécutera une fois, ce que je viens de comprendre, comme :


>>> def add(x,y):
    z=x+y
    print(z)
>>>a=add(3,4)
7
Copier après la connexion

Bien que une seule instruction d'affectation est exécutée ici, le résultat 7 est affiché, indiquant que la fonction de processus d'affectation add est exécutée. Cependant, la valeur de a est None et ne peut être affichée que via l'instruction d'impression. Non seulement la fonction de procédure d'affectation sera exécutée, mais également l'instruction return qui y est écrite.


>>>def log(func):
   def wrapper(*args, **kw):
     print('call %s():' % func.__name__)
     return func(*args, **kw)
   return wrapper
>>>@log
>>>def now():
    print('2015-3-25')
Copier après la connexion

C'est la routine dans la section décorateur du didacticiel Python du professeur Liao Xuefeng. Au début, je pensais que l'instruction return func(*args,**kw) renvoyait la fonction now() (. c'est-à-dire la fonction func), il a été découvert plus tard que la fonction now n'a pas de valeur de retour, qui est None, donc en fait, cette instruction est exécutée pendant le processus d'affectation, c'est-à-dire que l'instruction print de la fonction now est exécutée.

Dans l'exercice suivant, une variante consiste à imprimer « début de l'appel » et « fin de l'appel » avant et après l'appel de fonction. Le programme écrit par un internaute ci-dessous ressemble à ceci : func(*args,**kw)


Au début, je n'ai pas bien compris pourquoi la phrase

a été utilisée. Plus tard, après l'avoir comprise, j'ai réalisé que la mission elle-même n'avait aucun sens. fait également fonctionner la fonction func, elle s'écrit donc
def wrapper(*args,**kw):
   print(t+'begin call')
   result=func(*args,**kw)
   print(t+'end call')
   return result
Copier après la connexion

result=func(*args,**kw)


Le résultat est le même.

def wrapper(*args,**kw):
   print(t+'begin call')
   func(*args,**kw)
   print(t+'end call')
Copier après la connexion

Résumé

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal