Table des matières
Écrire du code pour l'implémenter
PEP0690 L'approche recommandée
Derniers mots
Références
Maison développement back-end Tutoriel Python Comment implémenter l'importation paresseuse-importation paresseuse de Python

Comment implémenter l'importation paresseuse-importation paresseuse de Python

Apr 20, 2023 am 11:04 AM
python 应用程序 模块

Si votre programme Python comporte un grand nombre d'importations et démarre très lentement, vous devriez essayer l'importation paresseuse. Cet article présente une méthode pour réaliser une importation paresseuse. Bien que PEP0690[1] ait proposé de permettre au compilateur Python (-L) ou à la bibliothèque standard d'ajouter cette fonctionnalité, la version actuelle de Python ne l'a pas encore implémentée.

Comme nous le savons tous, les applications Python effectueront des opérations d'importation avant d'effectuer les opérations réelles de l'utilisateur. Différents modules peuvent provenir de différents emplacements, l'exécution de certains modules peut prendre beaucoup de temps et certains modules peuvent ne pas être appelés par. l'utilisateur du tout. Par conséquent, l'importation de nombreux modules est une perte de temps.

Nous avons donc besoin d'une importation paresseuse. Lors de l'application d'une importation paresseuse, l'exécution de import foo ajoutera uniquement le nom foo à l'espace de nom complet global (globals()) comme référence paresseuse. Le compilateur rencontre un accès. La véritable opération d'importation sera effectuée. uniquement dans le code de foo. De même, from foo import bar ajoutera bar à l'espace de noms, et lorsqu'il rencontrera du code qui appelle bar, il importera foo.

Écrire du code pour l'implémenter

Alors, comment écrire du code pour l'implémenter ? En fait, il n'est pas nécessaire d'écrire du code pour l'implémenter. Il existe déjà des projets qui implémentent la fonction d'importation paresseuse, c'est-à-dire TensorFlow. Son code ne dépend d'aucune bibliothèque tierce. lorsque vous avez besoin d'une importation paresseuse, vous pouvez directement mettre la classe LazyLoader[2]. Copiez-la simplement dans votre propre projet.

Le code source est le suivant :

# Code copied from https://github.com/tensorflow/tensorflow/blob/master/tensorflow/python/util/lazy_loader.py
"""A LazyLoader class."""

from __future__ import absolute_import
from __future__ import division
from __future__ import print_function

import importlib
import types


class LazyLoader(types.ModuleType):
"""Lazily import a module, mainly to avoid pulling in large dependencies.

`contrib`, and `ffmpeg` are examples of modules that are large and not always
needed, and this allows them to only be loaded when they are used.
"""

# The lint error here is incorrect.
def __init__(self, local_name, parent_module_globals, name):# pylint: disable=super-on-old-class
self._local_name = local_name
self._parent_module_globals = parent_module_globals

super(LazyLoader, self).__init__(name)

def _load(self):
# Import the target module and insert it into the parent's namespace
module = importlib.import_module(self.__name__)
self._parent_module_globals[self._local_name] = module

# Update this object's dict so that if someone keeps a reference to the
# LazyLoader, lookups are efficient (__getattr__ is only called on lookups
# that fail).
self.__dict__.update(module.__dict__)

return module

def __getattr__(self, item):
module = self._load()
return getattr(module, item)

def __dir__(self):
module = self._load()
return dir(module)
Copier après la connexion

Description du code :

La classe LazyLoader hérite de types.ModuleType La fonction d'initialisation garantit que le module paresseux sera correctement ajouté à la variable globale comme un vrai module. car le module est réellement utilisé, c'est-à-dire que lorsque __getattr__ ou __dir__ est exécuté, le module réel est réellement importé, la variable globale est mise à jour pour pointer vers le module réel et tout son statut (__dict__) est mis à jour vers l'état du module réel afin de référencer le chargement retardé et de charger le module. Il n'est pas nécessaire de passer par le processus de chargement à chaque visite.

Utilisation du code :

Normalement, nous importons le module comme ceci :

import tensorflow.contrib as contrib
Copier après la connexion

La version d'importation différée correspondante est la suivante :

contrib = LazyLoader('contrib', globals(), 'tensorflow.contrib')
Copier après la connexion

PEP0690 L'approche recommandée

La proposition de PEP0690 est de le compiler dans le compilateur ( Code C), implémentation de la couche, les performances seront donc meilleures. Il existe deux façons de l'utiliser.

One way

Une méthode consiste à ajouter le paramètre -L lors de l'exécution du script Python. Par exemple, il existe deux fichiers spam.py avec le contenu suivant :

import time
time.sleep(10)
print("spam loaded")
Copier après la connexion

egg.py avec le contenu suivant. :

import spam
print("imports done")
Copier après la connexion

Import normal Dans ce cas, "spam chargé" sera imprimé en premier après 10 secondes, puis "importations terminées" sera imprimé lors de l'exécution de python -L Eggs.py, le module spam ne sera jamais importé. , et le module anti-spam appliqué ne sera pas utilisé du tout. Si le contenu de egg.py est le suivant :

import spam
print("imports done")
spam
Copier après la connexion

Lorsque python -L Eggs.py est exécuté, "importations effectuées" sera imprimé en premier et "spam chargé" sera imprimé 10 secondes plus tard).

Deuxième

Une autre façon consiste à appeler la méthode importlib de la bibliothèque standard :

import importlib 
importlib.set_lazy_imports(True)
Copier après la connexion

Si certains modules ne peuvent pas être chargés paresseux et doivent être exclus, vous pouvez le faire

import importlib 
importlib.set_lazy_imports(True,excluding=["one.mod", "another"])
Copier après la connexion

Vous pouvez également le faire :

from importlib import eager_imports

with eager_imports():
import foo
import bar
Copier après la connexion

Derniers mots

Après des tests effectués par des professionnels sur un véritable programme de ligne de commande Python, l'application d'une importation paresseuse peut augmenter le temps de démarrage de 70 % et réduire l'utilisation de la mémoire de 40 %, ce qui est très impressionnant.

Références

[1]PEP0690 : https://github.com/python/peps/blob/main/pep-0690.rst

[2]LazyLoader : https://github.com/tensorflow/tensorflow / blob/master/tensorflow/python/util/lazy_loader.py

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 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

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)
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Commandes de chat et comment les utiliser
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

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

Python: jeux, GUIS, et plus Python: jeux, GUIS, et plus Apr 13, 2025 am 12:14 AM

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: comparaison de deux langages de programmation populaires PHP et Python: comparaison de deux langages de programmation populaires Apr 14, 2025 am 12:13 AM

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.

Comment Debian Readdir s'intègre à d'autres outils Comment Debian Readdir s'intègre à d'autres outils Apr 13, 2025 am 09:42 AM

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) {

Python et temps: tirer le meilleur parti de votre temps d'étude Python et temps: tirer le meilleur parti de votre temps d'étude Apr 14, 2025 am 12:02 AM

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.

Certificat NGINX SSL Mise à jour du tutoriel Debian Certificat NGINX SSL Mise à jour du tutoriel Debian Apr 13, 2025 am 07:21 AM

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

Comment configurer le serveur HTTPS dans Debian OpenSSL Comment configurer le serveur HTTPS dans Debian OpenSSL Apr 13, 2025 am 11:03 AM

La configuration d'un serveur HTTPS sur un système Debian implique plusieurs étapes, notamment l'installation du logiciel nécessaire, la génération d'un certificat SSL et la configuration d'un serveur Web (tel qu'Apache ou Nginx) pour utiliser un certificat SSL. Voici un guide de base, en supposant que vous utilisez un serveur Apacheweb. 1. Installez d'abord le logiciel nécessaire, assurez-vous que votre système est à jour et installez Apache et OpenSSL: SudoaptupDaSuDoaptupgradeSudoaptinsta

Guide de développement du plug-in de Gitlab sur Debian Guide de développement du plug-in de Gitlab sur Debian Apr 13, 2025 am 08:24 AM

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é

Quel service est Apache Quel service est Apache Apr 13, 2025 pm 12:06 PM

Apache est le héros derrière Internet. Ce n'est pas seulement un serveur Web, mais aussi une plate-forme puissante qui prend en charge un trafic énorme et fournit un contenu dynamique. Il offre une flexibilité extrêmement élevée grâce à une conception modulaire, permettant l'expansion de diverses fonctions au besoin. Cependant, la modularité présente également des défis de configuration et de performance qui nécessitent une gestion minutieuse. Apache convient aux scénarios de serveur qui nécessitent des besoins complexes hautement personnalisables.

See all articles