Repository with sources and generator of https://larlet.fr/david/ https://larlet.fr/david/
Ви не можете вибрати більше 25 тем Теми мають розпочинатися з літери або цифри, можуть містити дефіси (-) і не повинні перевищувати 35 символів.

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182
  1. <!doctype html>
  2. <html lang=fr>
  3. <head>
  4. <!-- Always define the charset before the title -->
  5. <meta charset=utf-8>
  6. <title>Python : lisibilité vs simplicité — Biologeek — David Larlet</title>
  7. <!-- Define a viewport to mobile devices to use - telling the browser to assume that the page is as wide as the device (width=device-width) and setting the initial page zoom level to be 1 (initial-scale=1.0) -->
  8. <meta name="viewport" content="width=device-width, initial-scale=1"/>
  9. <!-- Fake favicon, to avoid extra request to the server -->
  10. <link rel="icon" href="data:;base64,iVBORw0KGgo=">
  11. <link type="application/atom+xml" rel="alternate" title="Feed" href="/david/log/" />
  12. <link rel="manifest" href="/manifest.json">
  13. <link rel="stylesheet" href="/static/david/css/larlet-david-_J6Rv.css" data-instant-track />
  14. <noscript>
  15. <style type="text/css">
  16. /* Otherwise fonts are loaded by JS for faster initial rendering. See scripts at the bottom. */
  17. body {
  18. font-family: 'EquityTextB', serif;
  19. }
  20. h1, h2, h3, h4, h5, h6, time, nav a, nav a:link, nav a:visited {
  21. font-family: 'EquityCapsB', sans-serif;
  22. font-variant: normal;
  23. }
  24. </style>
  25. </noscript>
  26. <!-- Canonical URL for SEO purposes -->
  27. <link rel="canonical" href="https://larlet.fr/david/biologeek/archives/20060425-python-et-underscore">
  28. </head>
  29. <body>
  30. <div>
  31. <header>
  32. <nav>
  33. <p>
  34. <small>
  35. Je suis <a href="/david/" title="Profil public">David Larlet</a>, <a href="/david/pro/" title="Activité professionnelle">artisan</a> du web qui vous <a href="/david/pro/accompagnement/" title="Activité d’accompagnement">accompagne</a><span class="more-infos"> dans l’acquisition de savoirs pour concevoir des <a href="/david/pro/produits-essentiels/" title="Qu’est-ce qu’un produit essentiel ?">produits essentiels</a></span>. <span class="more-more-infos">Discutons ensemble d’une <a href="/david/pro/devis/" title="En savoir plus">non-demande de devis</a>.</span> Je partage ici mes <a href="/david/blog/" title="Expériences bienveillantes">réflexions</a> et <a href="/david/correspondances/2017/" title="Lettres hebdomadaires">correspondances</a>.
  36. </small>
  37. </p>
  38. </nav>
  39. </header>
  40. <section>
  41. <h1 property="schema:name">Python : lisibilité vs simplicité</h1>
  42. <article typeof="schema:BlogPosting">
  43. <div property="schema:articleBody">
  44. <img src="/static/david/biologeek/images/logos/python_nouveau.png" alt="vignette" style="float:left; margin: 0.5em 1em;" property="schema:thumbnailUrl" />
  45. <p>Le programmeur est fainéant. C'est ainsi. S'il ne l'était pas, il n'essayerait pas de s'aider d'un ordinateur. Du coup il évite dans la mesure du possible de s'encombrer de variables trop longues, ou d'appels répétitifs un peu trop élaborés. Heureusement, en Python, on peut simplifier tout ça. Mais la simplification peut mener à un manque de lisibilité dans certains cas. Un cas intéressant est celui de l'underscore.</p>
  46. <h2>La valeur précédente</h2>
  47. <p>Pas grand monde ne le sait mais testez de vous-même dans un shell&nbsp;:</p>
  48. <pre>&gt;&gt;&gt; 8 + 2
  49. 10
  50. &gt;&gt;&gt; _
  51. 10</pre>
  52. <p>C'est très peu employé et ça rend le code très peu lisible, quitte a avoir une variable temporaire rappelant la dernière valeur autant qu'on comprenne de quoi il retourne. Surtout qu'il est possible d'attribuer d'autres fonctions à l'underscore.</p>
  53. <h2>Variable temporaire inutile</h2>
  54. <p>L'underscore est souvent utilisé pour créer des listes de liste&nbsp;:</p>
  55. <pre>&gt;&gt;&gt; [[0] for _ in range(3)]
  56. [[0], [0], [0]]</pre>
  57. <p>Vous vous demandez peut-être pourquoi ne pas faire un simple&nbsp;:</p>
  58. <pre>&gt;&gt;&gt; [[0]] * 3</pre>
  59. <p>Tout simplement car ça crée des copies de listes et non des nouvelles listes donc si vous en modifiez une, ça se répercute sur les autres.</p>
  60. <p>Il peut être aussi utilisé pour des fonctions renvoyant trop d'information, par exemple dans&nbsp;:</p>
  61. <pre>&gt;&gt;&gt; jour, mois, _ = date_actuelle()</pre>
  62. <p>Si l'on ne veut pas s'encombrer de l'année (en supposant que le troisième argument renvoyé par la fonction est l'année bien sûr...).</p>
  63. <p>Ces utilisations ponctuelles sont pratiques et ne nuisent pas trop à la lisibilité du code.</p>
  64. <h2>Traduction avec gettext</h2>
  65. <pre>import gettext
  66. gettext.bindtextdomain('myapplication', '/path/to/my/language/directory')
  67. gettext.textdomain('myapplication')
  68. _ = gettext.gettext
  69. # ...
  70. print _('This is a translatable string.')</pre>
  71. <p>Ça par contre c'est très employé, et oui les programmeurs sont des fainéants ;-). C'est pas forcément lisible et ça demande un peu d'habitude mais il faut reconnaître que c'est bien pratique et que c'est devenu usage courant donc autant l'utiliser.</p>
  72. <h2>Utilisation à la place de self</h2>
  73. <p>C'est souvent demandé à Guido sur la mailing-list python et il est assez intransigeant là-dessus (et je suis d'accord avec lui). Python est un langage simple et on doit pas tomber dans les gri-gri de Perl (désolé pour les mongeurs dans l'assistance...). Alors bien sûr vous <em>pouvez</em> utiliser n'importe quel mot-clé à la place de self pour vos classes et plus il est court moins vous aurez à taper de caractère ensuite mais <strong>self</strong> est un bon compromis, il est à la fois court et lisible. Pensez aux personnes qui vont devoir relire un jour votre code (il est très probable que ce soit vous et que vous ayez évolué !), autant se baser sur un formalisme commun (parce que ça commence comme ça puis on se met à utiliser <strong>*</strong> à la place de <strong>yield</strong> et on finit avec un code illisible...).</p>
  74. <p>Python est un des langages les plus lisible mais aussi un des plus paramétrable (j'entend par là entièrement redéfinissable au niveau des mots-clé, des fonctions, etc...). Essayez de ne pas suivre des méthodes reconnues pour être la <a href="http://www.thc.org/root/phun/unmaintain.html">clé de votre engagement à vie dans votre boîte</a> ;-).</p>
  75. </div>
  76. </article>
  77. <footer>
  78. <h6 property="schema:datePublished">— 25/04/2006</h6>
  79. </footer>
  80. </section>
  81. <section>
  82. <div>
  83. <h3>Articles peut-être en rapport</h3>
  84. <ul>
  85. <li><a href="/david/biologeek/archives/20080511-bonnes-pratiques-et-astuces-python/" title="Accès à Bonnes pratiques et astuces Python">Bonnes pratiques et astuces Python</a></li>
  86. <li><a href="/david/biologeek/archives/20061025-benchmarks-map-filter-vs-list-comprehensions/" title="Accès à Benchmarks map, filter vs. list-comprehensions">Benchmarks map, filter vs. list-comprehensions</a></li>
  87. <li><a href="/david/biologeek/archives/20060304-principales-nouveautes-dans-python-25/" title="Accès à Principales nouveautés dans Python 2.5">Principales nouveautés dans Python 2.5</a></li>
  88. </ul>
  89. </div>
  90. </section>
  91. <section>
  92. <div id="comments">
  93. <h3>Commentaires</h3>
  94. <div class="comment" typeof="schema:UserComments">
  95. <p class="comment-meta">
  96. <span class="comment-author" property="schema:creator">Milou</span> le <span class="comment-date" property="schema:commentTime">26/04/2006</span> :
  97. </p>
  98. <div class="comment-content" property="schema:commentText">
  99. <p>Aïe le retour du geek...<br />
  100. Je peux trop rien dire sur le fond, mais par contre...<br />
  101. Voilà ce que ça donne de poster à des heures indécentes de la nuit :<br />
  102. &quot;C'est utilisation ponctuelle sont pratique et ne nuisent pas trop à la lisibilité du code.&quot;<br />
  103. Sans commentaire...<br />
  104. <br />
  105. </p>
  106. </div>
  107. </div>
  108. <div class="comment" typeof="schema:UserComments">
  109. <p class="comment-meta">
  110. <span class="comment-author" property="schema:creator">David, biologeek</span> le <span class="comment-date" property="schema:commentTime">26/04/2006</span> :
  111. </p>
  112. <div class="comment-content" property="schema:commentText">
  113. <p>Damn! Corrigé...</p>
  114. </div>
  115. </div>
  116. <div class="comment" typeof="schema:UserComments">
  117. <p class="comment-meta">
  118. <span class="comment-author" property="schema:creator">gapz</span> le <span class="comment-date" property="schema:commentTime">28/04/2006</span> :
  119. </p>
  120. <div class="comment-content" property="schema:commentText">
  121. <p>Pas mal le coup de l'underscore, je ne connaissais pas, très pratique :-) </p>
  122. </div>
  123. </div>
  124. <div class="comment" typeof="schema:UserComments">
  125. <p class="comment-meta">
  126. <span class="comment-author" property="schema:creator">Krunch</span> le <span class="comment-date" property="schema:commentTime">05/05/2006</span> :
  127. </p>
  128. <div class="comment-content" property="schema:commentText">
  129. <p>Ha mais si ya des bouts de Haskell, le Python c'est peut-être pas si mal alors (par contre faudrait patcher l'arbre généalogique des langages de programmation).</p>
  130. </div>
  131. </div>
  132. </div>
  133. </section>
  134. <footer>
  135. <nav>
  136. <p>
  137. <small>
  138. Je réponds quasiment toujours aux <a href="m&#x61;ilto:d&#x61;vid%40l&#x61;rlet&#46;fr" title="Envoyer un email">emails</a> (<a href="/david/signature/" title="Ma signature actuelle avec possibilité de chiffrement">signés</a>) et vous pouvez me rencontrer à Montréal. <span class="more-infos">N’hésitez pas à <a href="/david/log/" title="Être tenu informé des mises à jour">vous abonner</a> pour être tenu informé des publications récentes.</span>
  139. </small>
  140. </p>
  141. </nav>
  142. </footer>
  143. </div>
  144. <script src="/static/david/js/larlet-david-3ee43f.js" data-no-instant></script>
  145. <script data-no-instant>InstantClick.init()</script>
  146. </body>
  147. </html>