recherche
Maisondéveloppement back-endTutoriel PythonConseils de performance Python que vous devez connaître

Python Code Performance Optimisation Stratégie complète

Python En tant que langage d'interprétation de type dynamique, la vitesse d'exécution peut être plus lente que le langage de compilation de type statique tel que C. Mais grâce à des techniques et stratégies spécifiques, les performances du code Python peuvent être considérablement améliorées. Cet article discutera de la façon d'optimiser le code Python pour le rendre plus rapide et plus efficace, et utiliser le module timeit de Python pour mesurer avec précision le code pour effectuer l'heure.

<:> Remarque: Par défaut, Le module répétera le code un million de fois pour garantir la précision et la stabilité du résultat de mesure. timeit

Exemple de code (en utilisant

Mesure timeit Temps d'exécution de la fonction): print_hi

import timeit

def print_hi(name):
    print(f'Hi, {name}')

if __name__ == '__main__':
    t = timeit.Timer(setup='from __main__ import print_hi', stmt='print_hi("leapcell")')
    print(t.timeit())
Python Script Running Time Calcul Method

Le

fournit une minuterie à haute précision dans le module, qui convient à la mesure d'un court intervalle de temps. Par exemple:

time time.perf_counter() I. Optimisation du fonctionnement des E / S-dense

import time

start_time = time.perf_counter()

# ...你的代码逻辑...

end_time = time.perf_counter()
run_time = end_time - start_time
print(f"程序运行时间: {run_time} 秒")

L'opération d'E / S-dense fait référence aux programmes ou tâches dépensés la plupart des procédures pour l'achèvement de l'opération d'E / S. Les opérations d'E / S incluent la lecture des données du disque, les données au disque, la communication réseau, etc. Ces opérations impliquent généralement des équipements matériels, de sorte que sa vitesse d'exécution est limitée aux performances matérielles et à la bande passante d'E / S. Les caractéristiques sont les suivantes:

Temps d'attente:

Lorsque le programme exécute l'opération d'E / S, il est généralement nécessaire d'attendre que les données transmettent les données des périphériques externes à la mémoire ou la transmission de la mémoire aux périphériques externes, ce qui peut entraîner l'exécution du programme blocage.

    Utilisation du processeur:

  1. En raison du temps d'attente de l'opération d'E / S, le CPU peut être dans un état libre au cours de cette période, entraînant un faible taux d'utilisation du CPU. Le goulot d'étranglement des performances:
  2. La vitesse de fonctionnement des E / S devient souvent un goulot d'étranglement des performances du programme, en particulier lorsque le volume de données est grand ou que la vitesse de transmission est lente.
  3. Par exemple, effectuez un million d'opérations à forte intensité d'E / S
  4. :
  5. Le résultat en cours d'exécution est d'environ 3 secondes. Et si vous appelez la méthode vide de ​​
  6. , la vitesse du programme sera considérablement améliorée:

print > Méthode d'optimisation de l'opération d'E / O-Dense:

import time
import timeit

def print_hi(name):
    print(f'Hi, {name}')
    return

if __name__ == '__main__':
    start_time = time.perf_counter()
    t = timeit.Timer(setup='from __main__ import print_hi', stmt='print_hi("leapcell")')
    t.timeit()
    end_time = time.perf_counter()
    run_time = end_time - start_time
    print(f"程序运行时间: {run_time} 秒")

Si nécessaire (comme la lecture et l'écriture de fichiers), vous pouvez utiliser les méthodes suivantes pour améliorer l'efficacité: print print_hi('xxxx')

E / S asynchrones:
def print_hi(name):
    return
Utiliser

et d'autres modèles de programmation asynchrones pour permettre aux programmes de continuer à effectuer d'autres tâches en attendant que l'opération d'E / S se termine, augmentant ainsi le taux d'utilisation du CPU. coussin:

Utilisez le tampon pour stocker temporairement les données pour réduire la fréquence des opérations d'E / S.

Traitement parallèle:
    Effectuez plusieurs opérations d'E / S en parallèle pour améliorer la vitesse de traitement de la vitesse des données globales.
  1. Structure de données optimisée: Sélectionnez la structure de données appropriée pour réduire le nombre de données de lecture et d'écriture. asyncio
  2. 2. Utilisez le générateur pour générer une liste et un dictionnaire
  3. Dans les versions Python 2.7 et suivantes, les générateurs de liste, de dictionnaire et de collecteur ont été améliorés pour rendre le processus de construction de la structure de données plus concise et plus efficace.
  4. <.> 1. Méthode traditionnelle:
  5. import timeit
    
    def print_hi(name):
        print(f'Hi, {name}')
    
    if __name__ == '__main__':
        t = timeit.Timer(setup='from __main__ import print_hi', stmt='print_hi("leapcell")')
        print(t.timeit())

    <.> 2. Utilisez l'optimisation du générateur:

    import time
    
    start_time = time.perf_counter()
    
    # ...你的代码逻辑...
    
    end_time = time.perf_counter()
    run_time = end_time - start_time
    print(f"程序运行时间: {run_time} 秒")
    La méthode d'utilisation du générateur est plus simple et plus rapide.

    trois, évitez les coutures de chaîne, utilisez

    join() Les méthodes connectent efficacement la chaîne, en particulier lorsqu'elle traite un grand nombre de chaînes, ce qui est plus rapide que

    les opérateurs ou

    format la mémoire plus rapide et enregistrent la mémoire. join() par exemple: %

    Utiliser :

    import time
    import timeit
    
    def print_hi(name):
        print(f'Hi, {name}')
        return
    
    if __name__ == '__main__':
        start_time = time.perf_counter()
        t = timeit.Timer(setup='from __main__ import print_hi', stmt='print_hi("leapcell")')
        t.timeit()
        end_time = time.perf_counter()
        run_time = end_time - start_time
        print(f"程序运行时间: {run_time} 秒")
    4. Utilisez

    au lieu du cycle join()

    Les fonctions
    def print_hi(name):
        return
    sont généralement plus efficaces que le cycle

    traditionnel. map() Méthode du cycle traditionnel:

    map() Utiliser for Fonction:

    5. Choisissez la bonne structure de données

    def fun1():
        list_ = []
        for i in range(100):
            list_.append(i)

    Le choix de la structure de données appropriée est essentiel pour améliorer l'efficacité de l'exécution du code Python. L'efficacité de recherche de dictionnaire est supérieure à la liste (en particulier sous un volume de données important), mais lorsque la quantité de petites données est le contraire. Lorsque vous êtes fréquemment et supprimé de nombreux éléments, envisagez d'utiliser . Lorsque vous recherchez fréquemment, envisagez d'utiliser la recherche map() à deux points.

    6. Évitez les appels de fonction inutiles
    def fun1():
        list_ = [i for i in range(100)]

    Réduire les appels de fonction inutiles, fusionner plusieurs opérations et améliorer l'efficacité.

    sept, évitez l'introduction inutile

    collections.deque bisect Réduisez l'importation inutile des modules et réduisez les dépenses.

    8. Évitez d'utiliser des variables globales

    Mettez le code à l'intérieur de la fonction, ce qui peut généralement augmenter la vitesse.

    neuf, évitez l'accès à l'attribut module et fonction

    Utiliser pour éviter les dépenses d'accès à l'attribut.

    dix, réduisez le calcul du cycle intérieur

    Calculez les valeurs qui peuvent être calculées à l'avance dans la boucle à l'avance pour réduire les calculs en double.

    (voici une introduction omise à la plate-forme LeapCell, car cela n'a rien à voir avec l'optimisation des performances du code Python)

    Veuillez noter que les méthodes d'optimisation ci-dessus ne sont pas toujours applicables et que la stratégie d'optimisation appropriée doit être sélectionnée en fonction de la situation spécifique. Performances et test Le code peut trouver la solution d'optimisation la plus efficace.

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!

Déclaration
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
Le plan Python de 2 heures: une approche réalisteLe plan Python de 2 heures: une approche réalisteApr 11, 2025 am 12:04 AM

Vous pouvez apprendre les concepts de programmation de base et les compétences de Python dans les 2 heures. 1. Apprenez les variables et les types de données, 2. Flux de contrôle maître (instructions et boucles conditionnelles), 3. Comprenez la définition et l'utilisation des fonctions, 4. Démarrez rapidement avec la programmation Python via des exemples simples et des extraits de code.

Python: Explorer ses applications principalesPython: Explorer ses applications principalesApr 10, 2025 am 09:41 AM

Python est largement utilisé dans les domaines du développement Web, de la science des données, de l'apprentissage automatique, de l'automatisation et des scripts. 1) Dans le développement Web, les cadres Django et Flask simplifient le processus de développement. 2) Dans les domaines de la science des données et de l'apprentissage automatique, les bibliothèques Numpy, Pandas, Scikit-Learn et Tensorflow fournissent un fort soutien. 3) En termes d'automatisation et de script, Python convient aux tâches telles que les tests automatisés et la gestion du système.

Combien de python pouvez-vous apprendre en 2 heures?Combien de python pouvez-vous apprendre en 2 heures?Apr 09, 2025 pm 04:33 PM

Vous pouvez apprendre les bases de Python dans les deux heures. 1. Apprenez les variables et les types de données, 2. Structures de contrôle maître telles que si les instructions et les boucles, 3. Comprenez la définition et l'utilisation des fonctions. Ceux-ci vous aideront à commencer à écrire des programmes Python simples.

Comment enseigner les bases de la programmation novice en informatique dans le projet et les méthodes axées sur les problèmes dans les 10 heures?Comment enseigner les bases de la programmation novice en informatique dans le projet et les méthodes axées sur les problèmes dans les 10 heures?Apr 02, 2025 am 07:18 AM

Comment enseigner les bases de la programmation novice en informatique dans les 10 heures? Si vous n'avez que 10 heures pour enseigner à l'informatique novice des connaissances en programmation, que choisissez-vous d'enseigner ...

Comment éviter d'être détecté par le navigateur lors de l'utilisation de Fiddler partout pour la lecture de l'homme au milieu?Comment éviter d'être détecté par le navigateur lors de l'utilisation de Fiddler partout pour la lecture de l'homme au milieu?Apr 02, 2025 am 07:15 AM

Comment éviter d'être détecté lors de l'utilisation de FiddlereVerywhere pour les lectures d'homme dans le milieu lorsque vous utilisez FiddlereVerywhere ...

Que dois-je faire si le module '__builtin__' n'est pas trouvé lors du chargement du fichier de cornichon dans Python 3.6?Que dois-je faire si le module '__builtin__' n'est pas trouvé lors du chargement du fichier de cornichon dans Python 3.6?Apr 02, 2025 am 07:12 AM

Chargement des fichiers de cornichons dans Python 3.6 Rapport de l'environnement Erreur: modulenotFoundError: NomoduLenamed ...

Comment améliorer la précision de la segmentation des mots jieba dans l'analyse des commentaires pittoresques?Comment améliorer la précision de la segmentation des mots jieba dans l'analyse des commentaires pittoresques?Apr 02, 2025 am 07:09 AM

Comment résoudre le problème de la segmentation des mots jieba dans l'analyse des commentaires pittoresques? Lorsque nous effectuons des commentaires et des analyses pittoresques, nous utilisons souvent l'outil de segmentation des mots jieba pour traiter le texte ...

Comment utiliser l'expression régulière pour correspondre à la première étiquette fermée et à s'arrêter?Comment utiliser l'expression régulière pour correspondre à la première étiquette fermée et à s'arrêter?Apr 02, 2025 am 07:06 AM

Comment utiliser l'expression régulière pour correspondre à la première étiquette fermée et à s'arrêter? Lorsque vous traitez avec HTML ou d'autres langues de balisage, des expressions régulières sont souvent nécessaires pour ...

See all articles

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌

Outils chauds

MantisBT

MantisBT

Mantis est un outil Web de suivi des défauts facile à déployer, conçu pour faciliter le suivi des défauts des produits. Cela nécessite PHP, MySQL et un serveur Web. Découvrez nos services de démonstration et d'hébergement.

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Puissant environnement de développement intégré PHP

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

PhpStorm version Mac

PhpStorm version Mac

Le dernier (2018.2.1) outil de développement intégré PHP professionnel

Listes Sec

Listes Sec

SecLists est le compagnon ultime du testeur de sécurité. Il s'agit d'une collection de différents types de listes fréquemment utilisées lors des évaluations de sécurité, le tout en un seul endroit. SecLists contribue à rendre les tests de sécurité plus efficaces et productifs en fournissant facilement toutes les listes dont un testeur de sécurité pourrait avoir besoin. Les types de listes incluent les noms d'utilisateur, les mots de passe, les URL, les charges utiles floues, les modèles de données sensibles, les shells Web, etc. Le testeur peut simplement extraire ce référentiel sur une nouvelle machine de test et il aura accès à tous les types de listes dont il a besoin.