fastapi/docs/fr/docs/virtual-environments.md

25 KiB
Raw Blame History

Environnements virtuels

Lorsque vous travaillez sur des projets Python, vous devriez probablement utiliser un environnement virtuel (ou un mécanisme similaire) pour isoler les packages que vous installez pour chaque projet.

/// info

Si vous connaissez déjà les environnements virtuels, comment les créer et les utiliser, vous pouvez passer cette section. 🤓

///

/// tip | Astuce

Un environnement virtuel est différent dune variable denvironnement.

Une variable denvironnement est une variable du système qui peut être utilisée par des programmes.

Un environnement virtuel est un répertoire contenant certains fichiers.

///

/// info

Cette page vous apprendra à utiliser les environnements virtuels et à comprendre leur fonctionnement.

Si vous êtes prêt à adopter un outil qui gère tout pour vous (y compris linstallation de Python), essayez uv.

///

Créer un projet

Commencez par créer un répertoire pour votre projet.

Ce que je fais généralement, cest créer un répertoire nommé code dans mon répertoire personnel/utilisateur.

Et à lintérieur, je crée un répertoire par projet.

// Aller au répertoire personnel
$ cd
// Créer un répertoire pour tous vos projets de code
$ mkdir code
// Entrer dans ce répertoire code
$ cd code
// Créer un répertoire pour ce projet
$ mkdir awesome-project
// Entrer dans ce répertoire de projet
$ cd awesome-project

Créer un environnement virtuel

Lorsque vous commencez à travailler sur un projet Python pour la première fois, créez un environnement virtuel dans votre projet.

/// tip | Astuce

Vous navez besoin de faire cela quune seule fois par projet, pas à chaque fois que vous travaillez.

///

//// tab | venv

Pour créer un environnement virtuel, vous pouvez utiliser le module venv fourni avec Python.

$ python -m venv .venv

/// details | Que signifie cette commande

  • python : utiliser le programme nommé python
  • -m : appeler un module comme un script, nous préciserons ensuite quel module
  • venv : utiliser le module nommé venv qui est normalement installé avec Python
  • .venv : créer lenvironnement virtuel dans le nouveau répertoire .venv

///

////

//// tab | uv

Si vous avez installé uv, vous pouvez lutiliser pour créer un environnement virtuel.

$ uv venv

/// tip | Astuce

Par défaut, uv créera un environnement virtuel dans un répertoire appelé .venv.

Mais vous pouvez le personnaliser en passant un argument supplémentaire avec le nom du répertoire.

///

////

Cette commande crée un nouvel environnement virtuel dans un répertoire appelé .venv.

/// details | .venv ou autre nom

Vous pourriez créer lenvironnement virtuel dans un autre répertoire, mais il est dusage de lappeler .venv.

///

Activer lenvironnement virtuel

Activez le nouvel environnement virtuel afin que toute commande Python que vous exécutez ou tout package que vous installez lutilise.

/// tip | Astuce

Faites cela à chaque fois que vous démarrez une nouvelle session de terminal pour travailler sur le projet.

///

//// tab | Linux, macOS

$ source .venv/bin/activate

////

//// tab | Windows PowerShell

$ .venv\Scripts\Activate.ps1

////

//// tab | Windows Bash

Ou si vous utilisez Bash pour Windows (par exemple Git Bash) :

$ source .venv/Scripts/activate

////

/// tip | Astuce

Chaque fois que vous installez un nouveau package dans cet environnement, activez de nouveau lenvironnement.

Vous vous assurez ainsi que si vous utilisez un programme de terminal (CLI) installé par ce package, vous utilisez celui de votre environnement virtuel et non un autre qui pourrait être installé globalement, probablement avec une version différente de celle dont vous avez besoin.

///

Vérifier que lenvironnement virtuel est actif

Vérifiez que lenvironnement virtuel est actif (la commande précédente a fonctionné).

/// tip | Astuce

Cest facultatif, mais cest une bonne manière de vérifier que tout fonctionne comme prévu et que vous utilisez lenvironnement virtuel voulu.

///

//// tab | Linux, macOS, Windows Bash

$ which python

/home/user/code/awesome-project/.venv/bin/python

Sil affiche le binaire python à .venv/bin/python, dans votre projet (dans cet exemple awesome-project), alors cela a fonctionné. 🎉

////

//// tab | Windows PowerShell

$ Get-Command python

C:\Users\user\code\awesome-project\.venv\Scripts\python

Sil affiche le binaire python à .venv\Scripts\python, dans votre projet (dans cet exemple awesome-project), alors cela a fonctionné. 🎉

////

Mettre à niveau pip

/// tip | Astuce

Si vous utilisez uv, vous lutiliserez pour installer des éléments à la place de pip, vous navez donc pas besoin de mettre pip à niveau. 😎

///

Si vous utilisez pip pour installer des packages (il est fourni par défaut avec Python), vous devez le mettre à niveau vers la dernière version.

Beaucoup derreurs exotiques lors de linstallation dun package se résolvent simplement en mettant dabord pip à niveau.

/// tip | Astuce

Vous feriez normalement cela une seule fois, juste après avoir créé lenvironnement virtuel.

///

Vous devez vous assurer que lenvironnement virtuel est actif (avec la commande ci-dessus), puis exécuter :

$ python -m pip install --upgrade pip

---> 100%

/// tip | Astuce

Parfois, vous pourriez obtenir une erreur No module named pip en essayant de mettre à niveau pip.

Si cela arrive, installez et mettez à niveau pip avec la commande ci-dessous :

$ python -m ensurepip --upgrade

---> 100%

Cette commande installera pip sil nest pas déjà installé et garantit aussi que la version de pip installée est au moins aussi récente que celle disponible dans ensurepip.

///

Ajouter .gitignore

Si vous utilisez Git (vous devriez), ajoutez un fichier .gitignore pour exclure tout ce qui se trouve dans votre .venv de Git.

/// tip | Astuce

Si vous avez utilisé uv pour créer lenvironnement virtuel, il la déjà fait pour vous, vous pouvez passer cette étape. 😎

///

/// tip | Astuce

Faites cela une seule fois, juste après avoir créé lenvironnement virtuel.

///

$ echo "*" > .venv/.gitignore

/// details | Que signifie cette commande

  • echo "*" : va « afficher » le texte * dans le terminal (la partie suivante change un peu cela)
  • > : tout ce qui est affiché dans le terminal par la commande à gauche de > ne doit pas être affiché mais écrit dans le fichier à droite de >
  • .gitignore : le nom du fichier dans lequel le texte doit être écrit

Et * signifie pour Git « tout ». Ainsi, il ignorera tout dans le répertoire .venv.

Cette commande créera un fichier .gitignore avec le contenu :

*

///

Installer des packages

Après avoir activé lenvironnement, vous pouvez y installer des packages.

/// tip | Astuce

Faites cela une seule fois lorsque vous installez ou mettez à niveau les packages nécessaires à votre projet.

Si vous devez mettre à niveau une version ou ajouter un nouveau package, vous le referez.

///

Installer des packages directement

Si vous êtes pressé et ne souhaitez pas utiliser un fichier pour déclarer les dépendances de votre projet, vous pouvez les installer directement.

/// tip | Astuce

Cest une très bonne idée de placer les packages et leurs versions nécessaires à votre programme dans un fichier (par exemple requirements.txt ou pyproject.toml).

///

//// tab | pip

$ pip install "fastapi[standard]"

---> 100%

////

//// tab | uv

Si vous avez uv :

$ uv pip install "fastapi[standard]"
---> 100%

////

Installer depuis requirements.txt

Si vous avez un requirements.txt, vous pouvez maintenant lutiliser pour installer ses packages.

//// tab | pip

$ pip install -r requirements.txt
---> 100%

////

//// tab | uv

Si vous avez uv :

$ uv pip install -r requirements.txt
---> 100%

////

/// details | requirements.txt

Un requirements.txt avec quelques packages pourrait ressembler à :

fastapi[standard]==0.113.0
pydantic==2.8.0

///

Exécuter votre programme

Après avoir activé lenvironnement virtuel, vous pouvez exécuter votre programme, et il utilisera le Python de votre environnement virtuel avec les packages que vous y avez installés.

$ python main.py

Hello World

Configurer votre éditeur

Vous utiliserez probablement un éditeur, assurez-vous de le configurer pour utiliser le même environnement virtuel que vous avez créé (il le détectera probablement automatiquement) afin davoir lautocomplétion et les erreurs inline.

Par exemple :

/// tip | Astuce

Vous devez normalement faire cela une seule fois, lorsque vous créez lenvironnement virtuel.

///

Désactiver lenvironnement virtuel

Une fois que vous avez fini de travailler sur votre projet, vous pouvez désactiver lenvironnement virtuel.

$ deactivate

Ainsi, lorsque vous exécutez python, il nessaiera pas de lexécuter depuis cet environnement virtuel avec les packages qui y sont installés.

Prêt à travailler

Vous êtes maintenant prêt à commencer à travailler sur votre projet.

/// tip | Astuce

Voulez-vous comprendre tout ce qui précède ?

Continuez la lecture. 👇🤓

///

Pourquoi des environnements virtuels

Pour travailler avec FastAPI, vous devez installer Python.

Ensuite, vous devrez installer FastAPI et tout autre package que vous souhaitez utiliser.

Pour installer des packages, vous utiliseriez normalement la commande pip fournie avec Python (ou des alternatives similaires).

Néanmoins, si vous utilisez simplement pip directement, les packages seraient installés dans votre environnement Python global (linstallation globale de Python).

Le problème

Alors, quel est le problème dinstaller des packages dans lenvironnement Python global ?

À un moment donné, vous finirez probablement par écrire de nombreux programmes différents qui dépendent de packages différents. Et certains de ces projets sur lesquels vous travaillez dépendront de versions différentes du même package. 😱

Par exemple, vous pourriez créer un projet appelé philosophers-stone, ce programme dépend dun autre package appelé harry, en version 1. Vous devez donc installer harry.

flowchart LR
    stone(philosophers-stone) -->|requires| harry-1[harry v1]

Puis, plus tard, vous créez un autre projet appelé prisoner-of-azkaban, et ce projet dépend aussi de harry, mais il a besoin de harry en version 3.

flowchart LR
    azkaban(prisoner-of-azkaban) --> |requires| harry-3[harry v3]

Mais maintenant, le problème est que, si vous installez les packages globalement (dans lenvironnement global) au lieu de dans un environnement virtuel local, vous devrez choisir quelle version de harry installer.

Si vous voulez exécuter philosophers-stone, vous devrez dabord installer harry en version 1, par exemple avec :

$ pip install "harry==1"

Et vous vous retrouverez avec harry en version 1 installé dans votre environnement Python global.

flowchart LR
    subgraph global[global env]
        harry-1[harry v1]
    end
    subgraph stone-project[philosophers-stone project]
        stone(philosophers-stone) -->|requires| harry-1
    end

Mais si vous voulez ensuite exécuter prisoner-of-azkaban, vous devrez désinstaller harry version 1 et installer harry version 3 (ou bien installer la version 3 désinstallerait automatiquement la version 1).

$ pip install "harry==3"

Et vous vous retrouverez alors avec harry version 3 installé dans votre environnement Python global.

Et si vous essayez dexécuter à nouveau philosophers-stone, il y a une chance que cela ne fonctionne pas car il a besoin de harry version 1.

flowchart LR
    subgraph global[global env]
        harry-1[<strike>harry v1</strike>]
        style harry-1 fill:#ccc,stroke-dasharray: 5 5
        harry-3[harry v3]
    end
    subgraph stone-project[philosophers-stone project]
        stone(philosophers-stone) -.-x|⛔️| harry-1
    end
    subgraph azkaban-project[prisoner-of-azkaban project]
        azkaban(prisoner-of-azkaban) --> |requires| harry-3
    end

/// tip | Astuce

Il est très courant que les packages Python fassent de leur mieux pour éviter les changements cassants dans les nouvelles versions, mais il vaut mieux jouer la sécurité et installer de nouvelles versions intentionnellement et lorsque vous pouvez exécuter les tests pour vérifier que tout fonctionne correctement.

///

Maintenant, imaginez cela avec beaucoup dautres packages dont tous vos projets dépendent. Cest très difficile à gérer. Et vous finiriez probablement par exécuter certains projets avec des versions incompatibles des packages, sans savoir pourquoi quelque chose ne fonctionne pas.

De plus, selon votre système dexploitation (par exemple Linux, Windows, macOS), il se peut quil soit livré avec Python déjà installé. Et dans ce cas, il avait probablement des packages préinstallés avec des versions spécifiques nécessaires à votre système. Si vous installez des packages dans lenvironnement Python global, vous pourriez finir par casser certains des programmes fournis avec votre système dexploitation.

Où les packages sont-ils installés

Lorsque vous installez Python, il crée des répertoires avec des fichiers sur votre ordinateur.

Certains de ces répertoires sont chargés de contenir tous les packages que vous installez.

Lorsque vous exécutez :

// Ne lexécutez pas maintenant, cest juste un exemple 🤓
$ pip install "fastapi[standard]"
---> 100%

Cela téléchargera un fichier compressé avec le code de FastAPI, normalement depuis PyPI.

Il téléchargera également des fichiers pour dautres packages dont FastAPI dépend.

Ensuite, il extraira tous ces fichiers et les placera dans un répertoire de votre ordinateur.

Par défaut, il placera ces fichiers téléchargés et extraits dans le répertoire fourni avec votre installation de Python, cest lenvironnement global.

Quest-ce quun environnement virtuel

La solution aux problèmes posés par le fait davoir tous les packages dans lenvironnement global est dutiliser un environnement virtuel pour chaque projet sur lequel vous travaillez.

Un environnement virtuel est un répertoire, très similaire à celui global, où vous pouvez installer les packages pour un projet.

De cette manière, chaque projet aura son propre environnement virtuel (répertoire .venv) avec ses propres packages.

flowchart TB
    subgraph stone-project[philosophers-stone project]
        stone(philosophers-stone) --->|requires| harry-1
        subgraph venv1[.venv]
            harry-1[harry v1]
        end
    end
    subgraph azkaban-project[prisoner-of-azkaban project]
        azkaban(prisoner-of-azkaban) --->|requires| harry-3
        subgraph venv2[.venv]
            harry-3[harry v3]
        end
    end
    stone-project ~~~ azkaban-project

Que signifie activer un environnement virtuel

Lorsque vous activez un environnement virtuel, par exemple avec :

//// tab | Linux, macOS

$ source .venv/bin/activate

////

//// tab | Windows PowerShell

$ .venv\Scripts\Activate.ps1

////

//// tab | Windows Bash

Ou si vous utilisez Bash pour Windows (par exemple Git Bash) :

$ source .venv/Scripts/activate

////

Cette commande créera ou modifiera certaines variables denvironnement{.internal-link target=_blank} qui seront disponibles pour les prochaines commandes.

Lune de ces variables est la variable PATH.

/// tip | Astuce

Vous pouvez en savoir plus sur la variable denvironnement PATH dans la section Variables denvironnement{.internal-link target=_blank}.

///

Activer un environnement virtuel ajoute son chemin .venv/bin (sur Linux et macOS) ou .venv\Scripts (sur Windows) à la variable denvironnement PATH.

Disons quavant dactiver lenvironnement, la variable PATH ressemblait à ceci :

//// tab | Linux, macOS

/usr/bin:/bin:/usr/sbin:/sbin

Cela signifie que le système chercherait des programmes dans:

  • /usr/bin
  • /bin
  • /usr/sbin
  • /sbin

////

//// tab | Windows

C:\Windows\System32

Cela signifie que le système chercherait des programmes dans:

  • C:\Windows\System32

////

Après avoir activé lenvironnement virtuel, la variable PATH ressemblerait à quelque chose comme ceci :

//// tab | Linux, macOS

/home/user/code/awesome-project/.venv/bin:/usr/bin:/bin:/usr/sbin:/sbin

Cela signifie que le système commencera maintenant par chercher des programmes dans:

/home/user/code/awesome-project/.venv/bin

avant de chercher dans les autres répertoires.

Ainsi, lorsque vous tapez python dans le terminal, le système trouvera le programme Python dans

/home/user/code/awesome-project/.venv/bin/python

et utilisera celui-ci.

////

//// tab | Windows

C:\Users\user\code\awesome-project\.venv\Scripts;C:\Windows\System32

Cela signifie que le système commencera maintenant par chercher des programmes dans:

C:\Users\user\code\awesome-project\.venv\Scripts

avant de chercher dans les autres répertoires.

Ainsi, lorsque vous tapez python dans le terminal, le système trouvera le programme Python dans

C:\Users\user\code\awesome-project\.venv\Scripts\python

et utilisera celui-ci.

////

Un détail important est quil placera le chemin de lenvironnement virtuel au début de la variable PATH. Le système le trouvera avant de trouver tout autre Python disponible. Ainsi, lorsque vous exécutez python, il utilisera le Python de lenvironnement virtuel au lieu de tout autre python (par exemple, un python dun environnement global).

Activer un environnement virtuel change aussi deux ou trois autres choses, mais cest lun des points les plus importants.

Vérifier un environnement virtuel

Lorsque vous vérifiez si un environnement virtuel est actif, par exemple avec :

//// tab | Linux, macOS, Windows Bash

$ which python

/home/user/code/awesome-project/.venv/bin/python

////

//// tab | Windows PowerShell

$ Get-Command python

C:\Users\user\code\awesome-project\.venv\Scripts\python

////

Cela signifie que le programme python qui sera utilisé est celui dans lenvironnement virtuel.

Vous utilisez which sous Linux et macOS et Get-Command sous Windows PowerShell.

La façon dont cette commande fonctionne est quelle va vérifier la variable denvironnement PATH, en parcourant chaque chemin dans lordre, à la recherche du programme nommé python. Une fois trouvé, elle vous affichera le chemin vers ce programme.

La partie la plus importante est que lorsque vous appelez python, cest exactement « python » qui sera exécuté.

Ainsi, vous pouvez confirmer si vous êtes dans le bon environnement virtuel.

/// tip | Astuce

Il est facile dactiver un environnement virtuel, dobtenir un Python, puis daller vers un autre projet.

Et le second projet ne fonctionnerait pas parce que vous utilisez le Python incorrect, provenant dun environnement virtuel dun autre projet.

Il est utile de pouvoir vérifier quel python est utilisé. 🤓

///

Pourquoi désactiver un environnement virtuel

Par exemple, vous pourriez travailler sur un projet philosophers-stone, activer cet environnement virtuel, installer des packages et travailler avec cet environnement.

Puis vous souhaitez travailler sur un autre projet prisoner-of-azkaban.

Vous allez vers ce projet :

$ cd ~/code/prisoner-of-azkaban

Si vous ne désactivez pas lenvironnement virtuel de philosophers-stone, lorsque vous exécutez python dans le terminal, il essaiera dutiliser le Python de philosophers-stone.

$ cd ~/code/prisoner-of-azkaban

$ python main.py

// Erreur lors de l'import de sirius, il n'est pas installé 😱
Traceback (most recent call last):
    File "main.py", line 1, in <module>
        import sirius

Mais si vous désactivez lenvironnement virtuel et activez le nouveau pour prisoner-of-askaban, alors lorsque vous exécuterez python, il utilisera le Python de lenvironnement virtuel de prisoner-of-azkaban.

$ cd ~/code/prisoner-of-azkaban

// Vous navez pas besoin dêtre dans lancien répertoire pour désactiver, vous pouvez le faire où que vous soyez, même après être allé dans lautre projet 😎
$ deactivate

// Activer lenvironnement virtuel dans prisoner-of-azkaban/.venv 🚀
$ source .venv/bin/activate

// Maintenant, lorsque vous exécutez python, il trouvera le package sirius installé dans cet environnement virtuel ✨
$ python main.py

I solemnly swear 🐺

Alternatives

Ceci est un guide simple pour vous lancer et vous montrer comment tout fonctionne en dessous.

Il existe de nombreuses alternatives pour gérer les environnements virtuels, les dépendances de packages (requirements), les projets.

Lorsque vous êtes prêt et souhaitez utiliser un outil pour gérer lensemble du projet, les dépendances, les environnements virtuels, etc., je vous suggère dessayer uv.

uv peut faire beaucoup de choses, il peut:

  • Installer Python pour vous, y compris différentes versions
  • Gérer lenvironnement virtuel pour vos projets
  • Installer des packages
  • Gérer les dépendances de packages et leurs versions pour votre projet
  • Vous assurer davoir un ensemble exact de packages et de versions à installer, y compris leurs dépendances, afin que vous puissiez être certain dexécuter votre projet en production exactement comme sur votre ordinateur pendant le développement, cela sappelle le locking
  • Et bien dautres choses

Conclusion

Si vous avez lu et compris tout cela, vous en savez maintenant bien plus sur les environnements virtuels que beaucoup de développeurs. 🤓

Connaître ces détails vous sera très probablement utile à lavenir lorsque vous déboguerez quelque chose qui semble complexe, mais vous saurez comment tout fonctionne en dessous. 😎