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.4 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
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292
  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. # À noter
  62. Seul deux des composants sont accessibles en *écriture* par
  63. mon utilisateur courant:
  64. * Le chemin courant
  65. * Un chemin dans mon $HOME (`~/.local/lib/python3.7/site-packages/`)
  66. Même principe sur macOS et Windows (presque)
  67. # Bibliothèques tierces
  68. Par example, pour faire des jolis tableaux:
  69. ```python
  70. import tabulate
  71. scores = [
  72. ["John", 345],
  73. ["Mary-Jane", 2],
  74. ["Bob", 543],
  75. ]
  76. table = tabulate.tabulate(score)
  77. print(table)
  78. ```
  79. ```
  80. --------- ---
  81. John 345
  82. Mary-Jane 2
  83. Bob 543
  84. --------- ---
  85. ```
  86. # Le problème
  87. On peut trouver le code source de `tabulate` facilement.
  88. Mais comment faire pour le mettre dans `sys.path`?
  89. # À la main
  90. On peut récupérer les sources et les installer avec `python3 setup.py install --user`
  91. * Quasiment *tous* les projets python on un `setup.py` utilisable de cette façon.
  92. * On utilise `--user` pour éviter des problèmes de permissions
  93. * Démo!
  94. # Anatomie du setup.py
  95. Un appel à `setuptools.setup()`. C'est tout
  96. ```python
  97. from setuptools import setup
  98. setup(
  99. name='tabulate',
  100. version='0.8.1',
  101. description='Pretty-print tabular data',
  102. py_modules=["tabulate"],
  103. scripts=["bin/tabulate"],
  104. ...
  105. )
  106. ```
  107. # À noter
  108. Sur linux, si le paquet contient des *scripts*, ils arriveront dans `~/.local/bin`.
  109. Sous macOS et Windows, ce sera un autre emplacement, mais qui *dépendra de la version de Python*.
  110. * Utilisez `python3 -m` quand c'est possible!
  111. # Avec pip
  112. * `pip` vient par défaut avec Python3
  113. * Vous pouvez aussi l'installer avec `get-pip.py`
  114. * Toujours le lancer avec `python3 -m pip`.
  115. # Dépendances
  116. Prenons une autre bibliothèque: `cli-ui`.
  117. Elle sert à faire des jolis programmes en couleur:
  118. ```python
  119. import cli_ui
  120. cli_ui.info_1("Ceci est une info importante")
  121. cli_ui.info("Ceci est en", cli_ui.bold, "gras")
  122. ```
  123. # Dépendances de cli-ui
  124. En fait, `cli-ui` utilise *d'autres* bibliothèques.
  125. Par example:
  126. ```python
  127. headers=["name", "score"]
  128. data = [
  129. [(bold, "John"), (green, 10.0)],
  130. [(bold, "Jane"), (green, 5.0)],
  131. ]
  132. cli_ui.info_table(data, headers=headers)
  133. ```
  134. Devinez qui s'occupe d'afficher le tableau!
  135. # Déclaration des dépendances
  136. Aussi dans setup.py:
  137. ```python
  138. setup(
  139. name="cli-ui",
  140. version="0.9.1",
  141. install_requires=[
  142. "tabulate",
  143. ...
  144. ],
  145. ...
  146. )
  147. ```
  148. # Intérêt de pip
  149. * Va chercher tout seul sur `pypi`
  150. * Lance `setup.py` tout seul (pour trouver les dépendances, et les installer)
  151. * S'utilise avec `python3 -m pip install --user ...`
  152. # Fonctionalités en plus
  153. * Peut supprimer quelque chose d'installé - `python3 -m pip uninstall <>`
  154. * Peut chercher sur `pypi` directement - `python3 -m pip search <>`
  155. * Peut lister ce qui est installé - `python3 -m pip list`
  156. # Limitations de pip seul
  157. * Il faut penser à utiliser `--user`
  158. * Si le paquet est déjà installé dans le système (genre `/usr/lib/` source linux),
  159. pip ne saura pas le mettre à jour - il faudra passer par le gestionnaire de paquet de
  160. la distribution
  161. # Versions de dépendances
  162. Parfois, les versions sont incompatibles entre elles!
  163. https://tankerhq.github.io/python-cli-ui/changelog.html#v0-8-0
  164. # Solution
  165. On peut donner des versions dans `setup.py`:
  166. ```python
  167. install_requires=[
  168. "cli-ui <= 0.8",
  169. ...
  170. ]
  171. ```
  172. # Plusieurs projets
  173. * Projet A utilise `cli-ui` 0.7
  174. * Projet B utilise `cli-ui` 0.9
  175. Comment faire pour travailler sur les deux projets?
  176. # Environements virtuels
  177. * Un chemin *isolé* du reste du système.
  178. * Contient un binaire python légèrement différent du binaire ordinaire.
  179. * Se crée avec `python3 -m venv <le chemin>` - sauf sous debian ;-(
  180. # Avec virtualenv
  181. * Vous pouvez aussi install `virtualenv` avec pip puis utiliser `virtualenv`
  182. ```bash
  183. $ python3 -m pip install virtualenv --user
  184. $ python3 -m virtualenv <le chemin>
  185. ```
  186. # L'isolation en pratique
  187. * Plus de chemin dans `~/.local/lib`
  188. * Moins de chemins dans le système
  189. * Les scripts restent dans le virtualenv
  190. # Pip + Virtualenv = <3
  191. Et vous avez aussi un `pip` spécial dans `/le chemin/bin/pip`
  192. * Plus besoin de `--user`
  193. * On peut créér deux virtualenvs différent pour les projets A et B
  194. # Activer un virtualenv
  195. Si taper le chemin du virtualenv vous embête, vous pouves
  196. *l'activer* avec `source bin/activate`
  197. Pour sortir: `deactivate`.