You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
This repo is archived. You can view files and clone it, but cannot push or open issues/pull-requests.

python-11.md 5.8 KiB

5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312
  1. % Programmation avec Python (chapitre 11)
  2. % Dimitri Merejkowsky
  3. \center \huge Retour sur les exceptions
  4. # A quoi sert finally?
  5. ```python
  6. try:
  7. fp = open("file.txt")
  8. 1 / 0
  9. except ZeroDivisionError:
  10. print("got you")
  11. finally:
  12. print("closing")
  13. fp.close()
  14. ```
  15. # versus
  16. ```python
  17. try:
  18. fp = open("file.txt")
  19. 1 / 0
  20. except ZeroDivisionError:
  21. print("got you")
  22. fp.close()
  23. ```
  24. # Réponse:
  25. Que se passe-t-il si l'exception *n'est pas* ZeroDivisionError?
  26. #
  27. \center \huge Utiliser des bibliothèques tierces
  28. # Rappel
  29. ```python
  30. import foo
  31. answer = foo.get_answer()
  32. ```
  33. Fonctionne si:
  34. * Il y a un `foo.py` quelque part qui contient une fonction `get_answer`
  35. * Dans le dossier courant
  36. * Ou dans la bibliothèque standard Python
  37. # Parlons de PATH
  38. * Vous connaissez peut-être la variable PATH, qui dit
  39. où sont les exécutables.
  40. ```bash
  41. PATH="/bin:/usr/bin:/usr/sbin"
  42. $ ifconfig
  43. # résout sur /usr/sbin/ifconfig
  44. $ ls
  45. # résount sur /bin/ls
  46. ```
  47. # sys.path
  48. En Python c'est pareil.
  49. ```python
  50. import sys
  51. print(sys.path)
  52. ```
  53. # Sur mon Arch
  54. ```
  55. * '' # vide = chemin courant
  56. * /usr/lib/python3.7
  57. * /usr/lib/python3.7/lib-dynload
  58. * /home/dmerej/.local/lib/python3.7/site-packages
  59. * /usr/lib/python3.7/site-packages
  60. ```
  61. * Le chemin courant à la priorité sur la bibliothèque standard!
  62. # À noter
  63. Seul deux des composants sont accessibles en *écriture* par
  64. mon utilisateur courant:
  65. * Le chemin courant
  66. * Un chemin dans mon $HOME (`~/.local/lib/python3.7/site-packages/`)
  67. Même principe sur macOS et Windows (presque)
  68. # Bibliothèques tierces
  69. Par example, pour faire des jolis tableaux:
  70. ```python
  71. import tabulate
  72. scores = [
  73. ["John", 345],
  74. ["Mary-Jane", 2],
  75. ["Bob", 543],
  76. ]
  77. table = tabulate.tabulate(score)
  78. print(table)
  79. ```
  80. ```
  81. --------- ---
  82. John 345
  83. Mary-Jane 2
  84. Bob 543
  85. --------- ---
  86. ```
  87. # Le problème
  88. On peut trouver le code source de `tabulate` facilement.
  89. Mais comment faire pour le mettre dans `sys.path`?
  90. # À la main
  91. On peut récupérer les sources et les installer avec `python3 setup.py install --user`
  92. * Quasiment *tous* les projets python ont un `setup.py` utilisable de cette façon.
  93. * On utilise `--user` pour éviter des problèmes de permissions
  94. * Démo!
  95. # Anatomie du setup.py
  96. Un appel à `setuptools.setup()`. C'est tout
  97. ```python
  98. from setuptools import setup
  99. setup(
  100. name='tabulate',
  101. version='0.8.1',
  102. description='Pretty-print tabular data',
  103. py_modules=["tabulate"],
  104. scripts=["bin/tabulate"],
  105. ...
  106. )
  107. ```
  108. # À noter
  109. Sur linux, si le paquet contient des *scripts*, ils arriveront dans `~/.local/bin`.
  110. Sous macOS et Windows, ce sera un autre emplacement, mais qui *dépendra de la version de Python*.
  111. * Utilisez `python3 -m` quand c'est possible!
  112. # Avec pip
  113. * `pip` vient par défaut avec Python3
  114. * Vous pouvez aussi l'installer avec `get-pip.py`
  115. * Toujours le lancer avec `python3 -m pip`.
  116. # Dépendances
  117. Prenons une autre bibliothèque: `cli-ui`.
  118. Elle sert à faire des jolis programmes en couleur:
  119. ```python
  120. import cli_ui
  121. cli_ui.info_1("Ceci est une info importante")
  122. cli_ui.info("Ceci est en", cli_ui.bold, "gras")
  123. ```
  124. # Dépendances de cli-ui
  125. En fait, `cli-ui` utilise *d'autres* bibliothèques.
  126. Par exemple:
  127. ```python
  128. headers=["name", "score"]
  129. data = [
  130. [(bold, "John"), (green, 10.0)],
  131. [(bold, "Jane"), (green, 5.0)],
  132. ]
  133. cli_ui.info_table(data, headers=headers)
  134. ```
  135. Devinez qui s'occupe d'afficher le tableau!
  136. # Déclaration des dépendances
  137. Aussi dans setup.py:
  138. ```python
  139. setup(
  140. name="cli-ui",
  141. version="0.9.1",
  142. install_requires=[
  143. "tabulate",
  144. ...
  145. ],
  146. ...
  147. )
  148. ```
  149. # Intérêt de pip
  150. * Va chercher tout seul sur `pypi`
  151. * Lance `setup.py` tout seul (pour trouver les dépendances, et les installer)
  152. * S'utilise avec `python3 -m pip install --user ...`
  153. # Fonctionnalités en plus
  154. * Peut supprimer quelque chose installé - `python3 -m pip uninstall <>`
  155. * Peut chercher sur `pypi` directement - `python3 -m pip search <>`
  156. * Peut lister ce qui est installé - `python3 -m pip list`
  157. # Limitations de pip seul
  158. * Il faut penser à utiliser `--user`
  159. * Si le paquet est déjà installé dans le système (genre `/usr/lib/` sous Linux),
  160. pip ne saura pas le mettre à jour - il faudra passer par le gestionnaire de paquet de
  161. la distribution
  162. # Versions de dépendances
  163. Parfois, les versions sont incompatibles entre elles!
  164. https://tankerhq.github.io/python-cli-ui/changelog.html#v0-8-0
  165. # Solution
  166. On peut donner des versions dans `setup.py`:
  167. ```python
  168. install_requires=[
  169. "cli-ui <= 0.8",
  170. ...
  171. ]
  172. ```
  173. # Plusieurs projets
  174. * Projet A utilise `cli-ui` 0.7
  175. * Projet B utilise `cli-ui` 0.9
  176. Comment faire pour travailler sur les deux projets?
  177. # Environements virtuels
  178. * Un chemin *isolé* du reste du système.
  179. * Contient un binaire python légèrement différent du binaire ordinaire.
  180. * Se crée avec `python3 -m venv <le chemin>` - sauf sous Debian ;-(
  181. # Avec virtualenv
  182. * Vous pouvez aussi installer `virtualenv` avec pip puis utiliser `virtualenv`
  183. ```bash
  184. $ python3 -m pip install virtualenv --user
  185. $ python3 -m virtualenv <le chemin>
  186. ```
  187. # L'isolation en pratique
  188. * Plus de chemin dans `~/.local/lib`
  189. * Moins de chemins dans le système
  190. * Les scripts restent dans le virtualenv
  191. # Pip + Virtualenv = <3
  192. Et vous avez aussi un `pip` spécial dans `/le chemin/bin/pip`
  193. * Plus besoin de `--user`
  194. * On peut créér deux virtualenvs différent pour les projets A et B
  195. # Activer un virtualenv
  196. Si taper le chemin du virtualenv vous embête, vous pouves
  197. *l'activer* avec `source bin/activate`
  198. Pour sortir: `deactivate`.
  199. # Les règles
  200. * Un virtualenv par projet et par version de Python
  201. * Toujours utiliser pip depuis un virtualenv
  202. C'est plus long, mais ça vous évitera un tas de problèmes ...
  203. # Pour aller plus loin
  204. * `requirements.txt`
  205. * `pipenv`
  206. * `poetry`
  207. Veillez à bien comprendre le problème que ces outils résolvent avant de vous
  208. en servir!
  209. On y reviendra