Skip to main content

Librairie pour l'importation optimisé de module python

Project description

impmagic

Informations

Librairie pour l'importation optimisé de module python. Fonctionne principalement avec des décorateurs, ce qui permet de charger les modules uniquement lorsqu'ils sont nécessaires. Toutes ces fonctions se basent sur un système de cache pour recharger plus rapidement les modules lorsqu'ils sont appelés par d'autres fonctions.

Prérequis

  • Python 3

Installation

pip install impmagic

Utilisation

Importer des modules avec un décorateur

Cette option permet d'importer les modules nécessaires à la fonction uniquement lorsque celle-ci est utilisé. Pour son fonctionnement, il faut lui envoyer une liste ou un tuple contenant des dictionnaires d'informations. Chaque dictionnaire doit contenir au minimum la clé module, mais peut également contenir une liste de sous-module (submodule) ou encore l'option as (comme les import classique)

@impmagic.loader(
        {'module':'zpp_args'},
        {'module':'os.path', 'submodule': ['exists']}, 
        {'module':'psutil', 'as': 'psfunction'}, 
        {'module':'toml_nxs.toml', 'submodule': ['TOML'], 'as': 'TOMLnxs'}
    )
    def function(self):
	    #MyCode

Importer des modules dans une fonction

Il est également possible de charger des modules dans une fonction. Pour cela, on utilise la méthode load. Nous pouvons lui envoyer un simple str avec le nom du module, mais nous pouvons également lui envoyer les mêmes types de données que le décorateur loader.

impmagic.load('os')

Enlever un module importé

Il est possible de supprimer d'une fonction un module qui a été importé précédemment. Il suffit d'appeler la méthode unload avec le nom du module en paramètre. Par défaut, le module restera dans le cache, il faut ajouter l'option uncache=True pour le supprimer également du cache.

impmagic.unload('os')

Réimporter un module

Il est possible de réimporter un module déjà importé. Cela peut être nécessaire lorsque nous faisons des tests sur un module et que nous voulons voir les changements de suite sans avoir besoin de quitter le shell en cours.

impmagic.reload('os')

Utiliser un module sans l'importer

Il est possible d'utiliser un module sans avoir besoin de l'importer grâce à la méthode get.

module = impmagic.get('os')
module.mkdir(dir)

Utiliser un module sans l'importer depuis un fichier

Il est possible d'utiliser un module sans avoir besoin de l'importer grâce à la méthode get.

module = impmagic.get_from_file('os.py')
module.mkdir(dir)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

impmagic-0.2.2.tar.gz (4.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

impmagic-0.2.2-py3-none-any.whl (5.1 kB view details)

Uploaded Python 3

File details

Details for the file impmagic-0.2.2.tar.gz.

File metadata

  • Download URL: impmagic-0.2.2.tar.gz
  • Upload date:
  • Size: 4.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: nexus/0.5.0 CPython/3.12.4 Windows/11

File hashes

Hashes for impmagic-0.2.2.tar.gz
Algorithm Hash digest
SHA256 5041092cc19dc8e059ff24c7a8f5fbaed8f01bb9466901ab99fa03a6e6096305
MD5 78fac171e6aa8f5b04ac98a50abc98e8
BLAKE2b-256 8d33ba9865739c993321fcd68a6716a802e1ead6429508ddebd1538f46938f8f

See more details on using hashes here.

File details

Details for the file impmagic-0.2.2-py3-none-any.whl.

File metadata

  • Download URL: impmagic-0.2.2-py3-none-any.whl
  • Upload date:
  • Size: 5.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: nexus/0.5.0 CPython/3.12.4 Windows/11

File hashes

Hashes for impmagic-0.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 407516b78a6db10820b45d8cf4226d907aee9e68a65ce792d37e31b591cbafb4
MD5 d0ad540477c68aaae1c2f694995596b9
BLAKE2b-256 aaeb3878f485c173208425b83f8b5bee71dfdb2cff214ac2544167468a87ea79

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page