virtualenv
Différences
Ci-dessous, les différences entre deux révisions de la page.
Les deux révisions précédentesRévision précédenteProchaine révision | Révision précédenteProchaine révisionLes deux révisions suivantes | ||
virtualenv [2021/02/26 16:52] – [Requirements.txt] serge | virtualenv [2022/02/23 18:21] – [Installation d'un package sans environnement virtuel] serge | ||
---|---|---|---|
Ligne 6: | Ligne 6: | ||
</ | </ | ||
- | * **[[https:// | + | =====Version de python===== |
- | =====Environnements virtuels en python===== | + | Si vous avez plusieurs versions de python, vous devez remplacer |
- | Un tuto avec du python2.7 en 2020, cela ne ferait pas sérieux! | + | python3 |
- | + | ||
- | | + | |
- | + | ||
- | ====Création d' | + | |
- | https:// | + | |
- | + | ||
- | Création d'un dossier tutorial-env dans le dossier de votre projet toto: / | + | |
- | / | + | |
- | + | ||
- | Activation de l' | + | |
- | source tutorial-env/ | + | |
- | le prompt devient | + | |
- | (tutorial-env) serge@127:/ | + | |
- | pour voir où vous êtes | + | |
- | ls | + | |
| | ||
+ | par | ||
+ | python3.x | ||
| | ||
+ | ou x = 6 ou 7 ou 8 ou 9 ou 10 ou 11 ... | ||
| | ||
| | ||
- | =====Lancer correctement python===== | + | =====Ressources===== |
- | * **[[https:// | + | * **[[https:// |
+ | * **[[https:// | ||
+ | ===== Installation d'un package sans environnement virtuel ===== | ||
+ | <code bash> | ||
+ | python3 -m pip install psutil --user | ||
+ | python3 -m mon_fichier.py | ||
+ | </ | ||
- | + | Notez le –user, ainsi que les -m.\\ | |
- | =====Ce qu'il faut retenir par cœur===== | + | Ceci va installer psutil dans ~.local, pas au niveau du système. L'option -m exécute pip en tant que module. Il y a un warning sur le python path, personnellement python m'a toujours trouvé les packages de .local, sur debian et ubuntu. |
- | ====Installer un package==== | + | Si besoin, ajouter à ~.bashrc |
- | Le package est installé dans le home du user: | + | <code bash> |
- | python3.7 -m pip install black --user | + | ====Liste des package installés localement==== |
- | + | Donc sans les packages du système et les packages installés dans le système. | |
- | Pour lancer un script: | + | python3 |
+ | ===== Environnement Virtuel ===== | ||
- | | + | ==== Installation de venv ==== |
+ | <code bash> | ||
+ | # Mise à jour de pip | ||
+ | python3 -m pip install --upgrade pip | ||
+ | # Installation de venv | ||
+ | sudo apt install python3-venv | ||
+ | </ | ||
+ | =====Ressources===== | ||
+ | * **https:// | ||
- | ====Mettre à jour pip==== | + | ==== Initialisation |
- | + | <code bash> | |
- | python3.7 -m pip install --upgrade pip | + | cd / |
- | + | # Création du dossier environnement si pas encore créé | |
- | Si vous avez cette alerte: | + | python3 -m venv mon_env |
- | | + | # Activation |
- | | + | source mon_env/ |
- | + | # le prompt devient (mon_env) machin@127:/../../../ | |
- | Ajouter au fichier ~/.bashrc | + | # Installation des package |
+ | python3 | ||
+ | # Installation d'un package supplémentaire | ||
+ | python3 | ||
+ | # Création ou re-création des requirements | ||
+ | pip freeze > requirements.txt | ||
+ | </ | ||
- | # Pour pip, pip3 and pip3.7 | + | ====Arguments spécifiques==== |
- | export PYTHONPATH=" | + | |
- | | + | |
+ | ===Installation avec les sources dans un dossier=== | ||
+ | <code bash> | ||
+ | ===Avec accès aux package système=== | ||
+ | * https:// | ||
+ | Permet à python du venv d' | ||
+ | <code bash> | ||
+ | | ||
+ | --no-site-packages est la valeur par défaut | ||
- | ===== Création de requirements.txt ===== | + | ===Depuis un Git=== |
- | Pour faciliter la distribution de votre projet dans son virtualenv, il est recommandé de produire un fichier requirements.txt qui listera toutes les dependances de votre projet. | + | <code bash> |
- | === Génération du fichier requirements.txt | + | ====Exécution d'un script de votre projet==== |
- | Pour générer | + | <code bash> |
- | pip freeze > requirements.txt | + | cd /le/ |
+ | ./ | ||
+ | # Dans Geany, commande de construction | ||
+ | ../ | ||
+ | </ | ||
+ | ==== Relance pour installer de nouveaux package ==== | ||
+ | <code bash> | ||
+ | cd / | ||
+ | source mon_env/ | ||
+ | python3 -m pip install some_package | ||
+ | # Mise à jour des requirements | ||
+ | pip freeze > requirements.txt | ||
+ | </ | ||
+ | ==== Génération du fichier requirements.txt ==== | ||
+ | Pour faciliter la distribution de votre projet dans son virtualenv, il est recommandé de produire un fichier requirements.txt qui listera toutes les dépendances de votre projet.\\ | ||
+ | C'est la liste de tous les paquets que vous avez installé pour votre projet. | ||
+ | <code bash>pip freeze > requirements.txt</ | ||
+ | | ||
+ | =====Création d'un venv avec une autre version de python===== | ||
+ | Installation de python 3.8 sur Xubuntu 18.04 | ||
+ | * https:// | ||
+ | <code bash> | ||
+ | sudo apt update | ||
+ | sudo apt install software-properties-common | ||
+ | sudo add-apt-repository ppa: | ||
+ | sudo apt install python3.8 | ||
+ | </ | ||
+ | Création d'un venv | ||
+ | <code bash> | ||
+ | cd / | ||
+ | python3.8 -m venv mon_env | ||
+ | sudo apt install python3.8-venv python3.8-dev | ||
+ | python3.8 -m venv mon_env | ||
+ | source mon_env/ | ||
+ | python3.8 -m pip install -r requirements.txt | ||
+ | </ | ||
- | | + | =====Travailler avec Geany et un Virtual Env===== |
+ | * **[[https:// | ||
+ | Dans " | ||
+ | ../ | ||
+ | {{: | ||
+ | {{: | ||
+ | {{tag> |
virtualenv.txt · Dernière modification : 2022/05/06 15:49 de serge