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/05/29 13:13] – [Ressources] serge | virtualenv [2022/02/23 18:21] – [Installation d'un package sans environnement virtuel] serge | ||
---|---|---|---|
Ligne 6: | Ligne 6: | ||
</ | </ | ||
+ | =====Version de python===== | ||
+ | Si vous avez plusieurs versions de python, vous devez remplacer | ||
+ | python3 | ||
+ | | ||
+ | par | ||
+ | python3.x | ||
+ | | ||
+ | ou x = 6 ou 7 ou 8 ou 9 ou 10 ou 11 ... | ||
+ | | ||
+ | | ||
=====Ressources===== | =====Ressources===== | ||
* **[[https:// | * **[[https:// | ||
* **[[https:// | * **[[https:// | ||
- | ====Installation d'un package sans environnement virtuel ==== | + | ===== Installation d'un package sans environnement virtuel |
- | Source: sametmax | + | |
- | < | + | < |
- | python3.7 -m pip install psutil --user | + | python3 -m pip install psutil --user |
- | python3.7 -m mon_fichier.py | + | python3 -m mon_fichier.py |
</ | </ | ||
- | Notez le –user, ainsi que les deux usages de -m.\\ | + | Notez le –user, ainsi que les -m.\\ |
- | Ceci va installer psutil | + | Ceci va installer psutil |
+ | Si besoin, ajouter à ~.bashrc | ||
+ | <code bash> | ||
+ | |||
+ | ====Liste des package installés localement==== | ||
+ | Donc sans les packages du système et les packages installés dans le système. | ||
+ | python3 -m pip list --user | ||
===== Environnement Virtuel ===== | ===== Environnement Virtuel ===== | ||
==== Installation de venv ==== | ==== Installation de venv ==== | ||
- | | + | <code bash> |
- | python3.7 -m pip install --upgrade pip | + | # Mise à jour de pip |
- | sudo apt install python3-venv | + | python3 -m pip install --upgrade pip |
- | | + | # Installation de venv |
+ | sudo apt install python3-venv | ||
+ | </ | ||
+ | =====Ressources===== | ||
+ | | ||
==== Initialisation ==== | ==== Initialisation ==== | ||
<code bash> | <code bash> | ||
cd / | cd / | ||
- | | ||
# Création du dossier environnement si pas encore créé | # Création du dossier environnement si pas encore créé | ||
python3 -m venv mon_env | python3 -m venv mon_env | ||
- | |||
# Activation | # Activation | ||
source mon_env/ | source mon_env/ | ||
# le prompt devient (mon_env) machin@127:/ | # le prompt devient (mon_env) machin@127:/ | ||
- | |||
# Installation des package | # Installation des package | ||
- | python3 -m pip install wheel # bug debian ubuntu | ||
python3 -m pip install -r requirements.txt | python3 -m pip install -r requirements.txt | ||
- | |||
# Installation d'un package supplémentaire | # Installation d'un package supplémentaire | ||
python3 -m pip install Pillow==7.1.1 | python3 -m pip install Pillow==7.1.1 | ||
- | |||
# Création ou re-création des requirements | # Création ou re-création des requirements | ||
pip freeze > requirements.txt | pip freeze > requirements.txt | ||
</ | </ | ||
+ | |||
+ | ====Arguments spécifiques==== | ||
+ | |||
+ | ===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 | ||
+ | |||
+ | ===Depuis un Git=== | ||
+ | <code bash> | ||
====Exécution d'un script de votre projet==== | ====Exécution d'un script de votre projet==== | ||
Ligne 53: | Ligne 84: | ||
cd / | cd / | ||
./ | ./ | ||
- | |||
# Dans Geany, commande de construction | # Dans Geany, commande de construction | ||
../ | ../ | ||
Ligne 59: | Ligne 89: | ||
==== Relance pour installer de nouveaux package ==== | ==== Relance pour installer de nouveaux package ==== | ||
- | | + | <code bash> |
- | source mon_env/ | + | cd / |
- | python3 -m pip install some_package | + | source mon_env/ |
- | # Mise à jour des requirements | + | python3 -m pip install some_package |
- | pip freeze > requirements.txt | + | # Mise à jour des requirements |
- | + | pip freeze > requirements.txt | |
- | + | ||
- | + | ||
- | Création d'un dossier tutorial-env dans le dossier de votre projet toto: / | + | |
- | / | + | |
- | + | ||
- | Activation de l' | + | |
- | source mon_env/ | + | |
- | le prompt devient (tutorial-env) mon_env@127:/ | + | |
- | pour voir où vous êtes et tester | + | |
- | ls | + | |
- | python3 | + | |
- | import sys | + | |
- | Ctrl + D pour quitter | + | |
- | + | ||
- | ===Installation d'un paquet dans cet environnement=== | + | |
- | python3 -m pip install Pillow==7.1.1 | + | |
- | Successfully installed Pillow-7.1.1, | + | |
- | pip show Pillow | + | |
- | pip list liste tous les paquets installés dans l' | + | |
- | pip list | + | |
- | + | ||
- | < | + | |
- | Package | + | |
- | ------------- ------- | + | |
- | Pillow | + | |
- | pip | + | |
- | pkg-resources 0.0.0 | + | |
- | setuptools | + | |
</ | </ | ||
- | |||
- | ===Installation de tous les paquets requis=== | ||
- | python3 -m pip install -r requirements.txt | ||
==== Génération du fichier 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 dependances | + | 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 |
C'est la liste de tous les paquets que vous avez installé pour 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 pythotn===== | + | =====Création d'un venv avec une autre version de python===== |
Installation de python 3.8 sur Xubuntu 18.04 | Installation de python 3.8 sur Xubuntu 18.04 | ||
* https:// | * https:// | ||
- | + | <code bash> | |
- | sudo apt update | + | sudo apt update |
- | sudo apt install software-properties-common | + | sudo apt install software-properties-common |
- | sudo add-apt-repository ppa: | + | sudo add-apt-repository ppa: |
- | sudo apt install python3.8 | + | sudo apt install python3.8 |
+ | </ | ||
Création d'un venv | Création d'un venv | ||
<code bash> | <code bash> | ||
Ligne 122: | Ligne 120: | ||
python3.8 -m pip install -r requirements.txt | python3.8 -m pip install -r requirements.txt | ||
</ | </ | ||
- | =====Lancer correctement python===== | ||
- | * **[[https:// | ||
- | Ne faites pas: | ||
- | sudo pip install black | ||
- | black mon_fichier.py | ||
- | Mais faites: | ||
- | python3.7 -m pip install black --user | ||
- | python3.7 -m black mon_fichier.py | ||
- | |||
- | Notez le --user, ainsi que les deux usages de -m.\\ | ||
- | Ceci va installer black localement, pas au niveau du système. On s’assure qu’on n’utilise bien Python3.6, à l’installation et à l’usage de black. Et comme on n’utilise -m, on a pas à se demander si la commande black est bien sur le PATH (pas besoin de trifouiller son .bashrc) | ||
=====Travailler avec Geany et un Virtual Env===== | =====Travailler avec Geany et un Virtual Env===== | ||
* **[[https:// | * **[[https:// | ||
Dans " | Dans " | ||
- | mon_env/ | + | |
{{: | {{: | ||
{{: | {{: | ||
- | =====Installation d'un package avec pip===== | ||
- | |||
- | ====Installer un package==== | ||
- | Le package est installé dans le home du user: | ||
- | |||
- | python3.7 -m pip install black --user | ||
- | | ||
- | Pour lancer un script: | ||
- | |||
- | python3.7 -m mon_fichier.py | ||
- | |||
- | ====Mettre à jour pip==== | ||
- | | ||
- | python3.7 -m pip install --upgrade pip | ||
- | | ||
- | Si vous avez cette alerte: | ||
- | WARNING: The scripts pip, pip3 and pip3.7 are installed in '/ | ||
- | Consider adding this directory to PATH or, if you prefer to suppress this warning, use --no-warn-script-location. | ||
- | | ||
- | Ajouter au fichier ~/.bashrc | ||
- | |||
- | # Pour pip, pip3 and pip3.7 | ||
- | export PYTHONPATH=" | ||
- | | ||
{{tag> | {{tag> |
virtualenv.txt · Dernière modification : 2022/05/06 15:49 de serge