Nie możesz wybrać więcej, niż 25 tematów Tematy muszą się zaczynać od litery lub cyfry, mogą zawierać myślniki ('-') i mogą mieć do 35 znaków.
To repozytorium jest zarchiwizowane. Możesz wyświetlać pliki i je sklonować, ale nie możesz do niego przepychać zmian lub otwierać zgłoszeń/Pull Requestów.

04-dépendances.md 5.5 KiB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. +++
  2. title = "Dépendances"
  3. weight = 4
  4. +++
  5. # Dépendances
  6. ## Un autre exemple
  7. Prenons une autre bibliothèque : `cli-ui`.
  8. Elle permet d'afficher du texte en couleur dans un terminal
  9. ```python
  10. import cli_ui
  11. cli_ui.info("Ceci est en", cli_ui.red, "rouge")
  12. ```
  13. Elle permet également d'afficher des tableaux en couleur :
  14. ```python
  15. headers=["prénom", "score"]
  16. data = [
  17. [(bold, "John"), (green, 10.0)],
  18. [(bold, "Jane"), (green, 5.0)],
  19. ]
  20. cli_ui.info_table(data, headers=headers)
  21. ```
  22. Pour ce faire, elle repose sur la bibliothèque `tabulate` vue précédemment. On dit que `cli-ui` *dépend* de `tabulate`.
  23. ## Déclaration des dépendances
  24. La déclaration de la dépendance de `cli-ui` vers `tabulate` s'effectue également dans le fichier `setup.py`:
  25. ```python
  26. setup(
  27. name="cli-ui",
  28. version="0.9.1",
  29. install_requires=[
  30. "tabulate",
  31. ...
  32. ],
  33. ...
  34. )
  35. ```
  36. ## pypi.org
  37. On comprend dès lors qu'il doit nécessairement exister un *annuaire* permettant de relier les noms de dépendances à leur code source.
  38. Cet annuaire, c'est le site [pypi.org](https://pypi.org/). Vous y trouverez les pages correspondant à [tabulate](https://pypi.org/project/tabulate/) et [cli-ui](https://pypi.org/project/python-cli-ui/).
  39. # pip
  40. `pip` est un outil qui vient par défaut avec Python3[^4]. Vous pouvez également l'installer grâce au script [get-pip.py](https://bootstrap.pypa.io/get-pip.py), en lançant `python3 get-pip.py --user`.
  41. Il est conseillé de *toujours* lancer `pip` avec `python3 -m pip`. De cette façon, vous êtes certains d'utiliser le module `pip` correspondant à votre binaire `python3`, et vous ne dépendez pas de ce qu'il y a dans votre `PATH`.
  42. `pip` est capable d'interroger le site `pypi.org` pour retrouver les dépendances, et également de lancer les différents scripts `setup.py`.
  43. Comme de nombreux outils, il s'utilise à l'aide de *commandes*. Voici comment installer `cli-ui` à l'aide de la commande 'install' de `pip`:
  44. ```bash
  45. $ python3 -m pip install cli-ui --user
  46. Collecting cli-ui
  47. ...
  48. Requirement already satisfied: unidecode in /usr/lib/python3.7/site-packages (from cli-ui) (1.0.23)
  49. Requirement already satisfied: colorama in /usr/lib/python3.7/site-packages (from cli-ui) (0.4.1)
  50. Requirement already satisfied: tabulate in /mnt/data/dmerej/src/python-tabulate (from cli-ui) (0.8.4)
  51. Installing collected packages: cli-ui
  52. Successfully installed cli-ui-0.9.1
  53. ```
  54. On constate ici quelques limitations de `pip`:
  55. * Il faut penser à utiliser `--user` (de la même façon que lorsqu'on lance `setup.py` à la main)
  56. * Si le paquet est déjà installé dans le système, pip ne saura pas le mettre à jour - il faudra passer par le gestionnaire de paquet de
  57. la distribution
  58. En revanche, `pip` contient de nombreuses fonctionnalités intéressantes:
  59. * Il est capable de désinstaller des bibliothèques (à condition toutefois qu'elles ne soient pas dans un répertoire système)
  60. * Il est aussi capable d'afficher la liste complète des bibliothèques Python accessibles par l'utilisateur courant avec `freeze`.
  61. Voici un extrait de la commande `python3 -m pip freeze` au moment de la rédaction de cet article sur ma machine:
  62. ```
  63. $ python3 -m pip freeze
  64. apipkg==1.5
  65. cli-ui==0.9.1
  66. gaupol==1.5
  67. tabulate==0.8.4
  68. ```
  69. On y retrouve les bibliothèques `cli-ui` et `tabulate`, bien sûr, mais aussi la bibliothèque `gaupol`, qui correspond au [programme d'édition de sous-titres](https://otsaloma.io/gaupol/) que j'ai installé à l'aide du gestionnaire de paquets de ma distribution. Précisons que les modules de la bibliothèque standard et ceux utilisés directement par pip sont omis de la liste.
  70. On constate également que chaque bibliothèque possède un *numéro de version*.
  71. ## Numéros de version
  72. Les numéros de version remplissent plusieurs rôles, mais l'un des principaux est de spécifier des changements incompatibles.
  73. Par exemple, pour `cli-ui`, la façon d'appeler la fonction `ask_choice` a changé entre les versions 0.7 et 0.8, comme le montre cet extrait du [changelog](https://tankerhq.github.io/python-cli-ui/changelog.html#v0-8-0):
  74. > the list of choices used by ask_choice is now a named keyword argument:
  75. ```python
  76. # Old (<= 0.7)
  77. ask_choice("select a fruit", ["apple", "banana"])
  78. # New (>= 0.8)
  79. ask_choice("select a fruit", choices=["apple", "banana"])
  80. ```
  81. Ceci s'appelle un *changement d'API*.
  82. ## Réagir aux changements d'API
  83. Plusieurs possibilités:
  84. * On peut bien sûr adapter le code pour utiliser la nouvelle API, mais cela n'est pas toujours possible ni souhaitable.
  85. * Une autre solution est de spécifier des *contraintes* sur le numéro de version dans la déclaration des dépendances. Par exemple :
  86. ```python
  87. setup(
  88. install_requires=[
  89. "cli-ui < 0.8",
  90. ...
  91. ]
  92. )
  93. ```
  94. # Aparté : pourquoi éviter sudo pip
  95. Souvenez-vous que les fichiers systèmes sont contrôlés par votre gestionnaire de paquets.
  96. Les mainteneurs de votre distribution font en sorte qu'ils fonctionnent bien les uns
  97. avec les autres. Par exemple, le paquet `python3-cli-ui` ne sera mis à jour que lorsque tous les paquets qui en dépendent seront prêts à utiliser la nouvelle API.
  98. En revanche, si vous lancez `sudo pip` (où `pip` avec un compte root), vous allez écrire dans ces mêmes répertoire et vous risquez de "casser" certains programmes de votre système.
  99. Mais il y a un autre problème encore pire.
  100. # Conflit de dépendances
  101. Supposons deux projets A et B dans votre répertoire personnel. Ils dépendent tous les deux de `cli-ui`, mais l'un des deux utilise `cli-ui 0.7` et l'autre `cli-ui 0.9`. Que faire ?