


Faites attention à l'explication détaillée des problèmes lors de l'attribution de fonctions aux variables en python
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
L'autre est
a=f()
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
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
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)
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
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
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')
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
def wrapper(*args,**kw): print(t+'begin call') result=func(*args,**kw) print(t+'end call') return result
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')
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!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Cet article expliquera comment améliorer les performances du site Web en analysant les journaux Apache dans le système Debian. 1. Bases de l'analyse du journal APACH LOG enregistre les informations détaillées de toutes les demandes HTTP, y compris l'adresse IP, l'horodatage, l'URL de la demande, la méthode HTTP et le code de réponse. Dans Debian Systems, ces journaux sont généralement situés dans les répertoires /var/log/apache2/access.log et /var/log/apache2/error.log. Comprendre la structure du journal est la première étape d'une analyse efficace. 2.

Python excelle dans les jeux et le développement de l'interface graphique. 1) Le développement de jeux utilise Pygame, fournissant des fonctions de dessin, audio et d'autres fonctions, qui conviennent à la création de jeux 2D. 2) Le développement de l'interface graphique peut choisir Tkinter ou Pyqt. Tkinter est simple et facile à utiliser, PYQT a des fonctions riches et convient au développement professionnel.

PHP et Python ont chacun leurs propres avantages et choisissent en fonction des exigences du projet. 1.Php convient au développement Web, en particulier pour le développement rapide et la maintenance des sites Web. 2. Python convient à la science des données, à l'apprentissage automatique et à l'intelligence artificielle, avec syntaxe concise et adaptée aux débutants.

La fonction ReadDir dans le système Debian est un appel système utilisé pour lire le contenu des répertoires et est souvent utilisé dans la programmation C. Cet article expliquera comment intégrer ReadDir avec d'autres outils pour améliorer sa fonctionnalité. Méthode 1: combinant d'abord le programme de langue C et le pipeline, écrivez un programme C pour appeler la fonction readdir et sortir le résultat: # include # include # include # includeIntmain (intargc, char * argv []) {dir * dir; structDirent * entrée; if (argc! = 2) {

Cet article traite de la méthode de détection d'attaque DDOS. Bien qu'aucun cas d'application directe de "Debiansniffer" n'ait été trouvé, les méthodes suivantes ne peuvent être utilisées pour la détection des attaques DDOS: technologie de détection d'attaque DDOS efficace: détection basée sur l'analyse du trafic: identification des attaques DDOS en surveillant des modèles anormaux de trafic réseau, tels que la croissance soudaine du trafic, une surtension dans des connexions sur des ports spécifiques, etc. Par exemple, les scripts Python combinés avec les bibliothèques Pyshark et Colorama peuvent surveiller le trafic réseau en temps réel et émettre des alertes. Détection basée sur l'analyse statistique: en analysant les caractéristiques statistiques du trafic réseau, telles que les données

Pour maximiser l'efficacité de l'apprentissage de Python dans un temps limité, vous pouvez utiliser les modules DateTime, Time et Schedule de Python. 1. Le module DateTime est utilisé pour enregistrer et planifier le temps d'apprentissage. 2. Le module de temps aide à définir l'étude et le temps de repos. 3. Le module de planification organise automatiquement des tâches d'apprentissage hebdomadaires.

Cet article vous guidera sur la façon de mettre à jour votre certificat NGINXSSL sur votre système Debian. Étape 1: Installez d'abord CERTBOT, assurez-vous que votre système a des packages CERTBOT et Python3-CERTBOT-NGINX installés. Si ce n'est pas installé, veuillez exécuter la commande suivante: Sudoapt-getUpDaSuDoapt-GetInstallCertBotpyThon3-Certerbot-Nginx Étape 2: Obtenez et configurez le certificat Utilisez la commande Certbot pour obtenir le certificat LETSCRYPT et configure

Développer un plugin Gitlab sur Debian nécessite des étapes et des connaissances spécifiques. Voici un guide de base pour vous aider à démarrer avec ce processus. Installation de GitLab Tout d'abord, vous devez installer GitLab sur votre système Debian. Vous pouvez vous référer au manuel d'installation officiel de Gitlab. Obtenez un jeton d'accès API avant d'effectuer l'intégration de l'API, vous devez d'abord obtenir le jeton d'accès API de GitLab. Ouvrez le tableau de bord GitLab, recherchez l'option "AccessTokens" dans les paramètres utilisateur et générez un nouveau jeton d'accès. Sera généré
