Repository with sources and generator of https://larlet.fr/david/ https://larlet.fr/david/
您最多选择25个主题 主题必须以字母或数字开头,可以包含连字符 (-),并且长度不得超过35个字符

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162
  1. title: Initialisation et modèles de données de la refonte
  2. slug: initialisation-et-modeles-de-donnees-de-la-refonte
  3. date: 2007-04-12 07:38:11
  4. type: post
  5. vignette: images/logos/biologeek.png
  6. contextual_title1: Biologeek (enfin) propulsé par Django
  7. contextual_url1: 20080423-biologeek-enfin-propulse-par-django
  8. contextual_title2: Ajout des flux RSS, du sitemap et des commentaires avec Django
  9. contextual_url2: 20070623-ajout-des-flux-rss-du-sitemap-et-des-commentaires-avec-django
  10. contextual_title3: De Dotclear à Django : migration des données et redirections
  11. contextual_url3: 20070523-de-dotclear-a-django-migration-des-donnees-et-redirections
  12. <p>Suite de la <a href="https://larlet.fr/david/biologeek/archives/20070224-objectifs-et-motivations-de-la-refonte-de-ce-blog/">refonte de ce blog</a>, qui a pris un peu de retard. Aujourd'hui on va de l'initialisation de l'environnement de développement au modèle de données retenu. Je pars vraiment de la base pour que vous puissiez réellement suivre la refonte si vous êtes intéressé(e). C'est d'ailleurs la raison pour laquelle j'ai mis le code sur un dépôt public (cf. fin du billet).</p>
  13. <h2>Initialisation</h2>
  14. <p>Commençons par installer django, j'ai décidé de mettre les sources dans <strong>~/web/</strong> car j'avais l'habitude d'avoir la dernière version à jour et c'est quand même plus pratique d'être dans sa home pour faire un svn up. Depuis la sortie de la 0.96, la version du dépôt officiel n'est plus aussi stable qu'avant (comme il était prévu), nous allons donc installer la version 0.96 pour la refonte&nbsp;:</p>
  15. <pre>$ cd &amp; cd web
  16. $ wget http://www.djangoproject.com/download/0.96/tarball/
  17. $ tar xvf Django-0.96.tar.gz &amp;&amp; rm Django-0.96.tar.gz
  18. $ sudo ln -sf /home/david/web/Django-0.96/django /usr/lib/python2.5/site-packages/</pre>
  19. <p>À adapter bien entendu à votre configuration (python 2.5 par défaut avec Feisty \o/). Normalement la commande <strong>ls -l /usr/lib/python2.5/site-packages/dj*</strong> devrait vous renvoyer&nbsp;:</p>
  20. <pre>lrwxrwxrwx 1 root root 34 2007-04-02 08:32 /usr/lib/python2.5/site-packages/django -&gt; /home/david/web/Django-0.96/django</pre>
  21. <p>Vous pouvez aussi vérifier en faisant un <strong>python -c "import django;print django.VERSION"</strong> qui ne devrait pas lever d'erreur et renvoyer <strong>(0, 96, None)</strong>. <em>Si vous récupérez directement les sources du projet, les étapes d'initialisation suivantes sont inutiles.</em></p>
  22. <p>Ok, tout marche bien, créons donc notre projet de refonte (par commodité, je me mets dans le dossier refonte)&nbsp;:</p>
  23. <pre>$ mkdir refonte &amp;&amp; cd refonte
  24. $ /usr/lib/python2.5/site-packages/django/bin/django-admin.py startproject biologeek
  25. $ cd biologeek/</pre>
  26. <p>Vous pouvez aussi mettre le répertoire <strong>bin</strong> de <strong>django</strong> dans votre <strong>$PATH</strong> pour ne pas avoir à aller le récupérer dans les paquets python mais comme je ne m'en sers que pour la création de projets je trouve ça un peu inutile.</p>
  27. <p>Il ne reste plus qu'à paramétrer tout ça en modifiant le fichier <strong>settings.py</strong> et vous pourrez alors synchroniser la base pour la première fois&nbsp;:</p>
  28. <pre>$ python manage.py syncdb</pre>
  29. <p>La création d'un super-utilisateur est demandée, une fois cet utilisateur créé, vous pouvez lancer votre serveur de développement pour la première fois&nbsp;:</p>
  30. <pre>$ python manage.py runserver</pre>
  31. <p>En vous rendant sur http://127.0.0.1:8000/ vous aurez le message de bienvenue et sur /admin/ vous pourrez accéder à votre interface d'administration (en décommentant la ligne dans urls.py).</p>
  32. <p>On va maintenant créer les deux «&nbsp;applications » de la refonte&nbsp;: <strong>journal</strong> et <strong>bistrot</strong>.</p>
  33. <pre>$ python manage.py startapp journal
  34. $ python manage.py startapp bistrot</pre>
  35. <p>Je m'arrête là pour l'initiation à Django, ces bases là suffisent pour comprendre ce qui va suivre, si vous voulez en savoir plus <a href="https://larlet.fr/david/biologeek/archives/20060617-traduction-francaise-de-la-documentation-de-django-le-framework-web-python/">rien ne vaut un bon tutoriel</a>.</p>
  36. <h2>Modèles de données</h2>
  37. <p>Le modèle de données doit être placé dans les fichiers <strong>models.py</strong> situés dans les répertoires des deux applications créées. Le journal va contenir des billets qui auront le modèle suivant&nbsp;:</p>
  38. <pre>class Post(models.Model):
  39. title = models.CharField('Titre', maxlength=200)
  40. slug = models.SlugField('Adresse', prepopulate_from=('title',), primary_key='True')
  41. tags = models.ManyToManyField(Tag, help_text='Sélectionnez les tags.')
  42. summary = models.TextField('Description', help_text='Différentes syntaxes possibles (cf. markup)', blank=True)
  43. summary_html = models.TextField('Description HTML', blank=True)
  44. content = models.TextField('Contenu', help_text='Difféntes syntaxes possibles (cf. markup)')
  45. content_html = models.TextField('Contenu HTML', blank=True)
  46. related_posts = models.ManyToManyField('self', help_text='Sélectionnez les billets en relation.', blank=True)
  47. related = models.TextField('Contenu additionnel', help_text='Difféntes syntaxes possibles (cf. markup)', blank=True)
  48. related_html = models.TextField('Contenu additionnel HTML', blank=True)
  49. creation_date = models.DateTimeField('Date de création')
  50. modification_date = models.DateTimeField('Date de modification')
  51. publication_date = models.DateTimeField('Date de publication', null=True, blank=True)
  52. image = models.ImageField('Image associée', upload_to='%s/media/logos/' % settings.PROJECT_PATH, blank=True)
  53. is_draft = models.BooleanField('Brouillon', default=True)
  54. is_bestof = models.BooleanField('Best of', default=False)
  55. markup = models.CharField(maxlength=20, choices=MARKUP_CHOICES, radio_admin=True, default='markdown')</pre>
  56. <p>Je ne vais pas détailler, les champs parlent d'eux-même. Par contre, il est intéressant de commenter le manager que j'ai associé&nbsp;:</p>
  57. <pre>class PostManager(models.Manager):
  58. def get_query_set(self):
  59. """ Retrieve only published posts. """
  60. qs = super(PostManager, self).get_query_set()
  61. return qs.filter(is_draft=False)
  62. def get_best_of(self):
  63. """ Retrieve only best of published posts. """
  64. qs = super(PostManager, self).get_query_set()
  65. return qs.filter(is_bestof=True)</pre>
  66. <p>Un manager permet d'accéder facilement à un catégorie de billets, il faut pour cela ajouter à votre classe Post par exemple&nbsp;:</p>
  67. <pre>class Post(models.Model):
  68. [...]
  69. objects = models.Manager()
  70. published = PostManager()</pre>
  71. <p>Et la récupération des données est simplifiée ainsi&nbsp;:</p>
  72. <ul>
  73. <li><strong>Post.objects.all()</strong> pour l'ensemble des données&nbsp;;</li>
  74. <li><strong>Post.published.all()</strong> pour l'ensemble des données publiées&nbsp;;</li>
  75. <li><strong>Post.published.get_best_of()</strong> pour l'ensemble des données publiées et sélectionnées.</li>
  76. </ul>
  77. <p>On peut faire beaucoup de choses avec les managers et c'est relativement pratique pour ne pas se tromper lorsque l'on doit continuellement filtrer des données à accès restreint.</p>
  78. <p>Pour les brèves du bistrot, le code est assez similaire&nbsp;:</p>
  79. <pre>class Thought(models.Model):
  80. title = models.CharField('Titre', maxlength=200)
  81. slug = models.SlugField('Adresse', prepopulate_from=('title',))
  82. tags = models.ManyToManyField(Tag, help_text='Sélectionnez les tags.')
  83. content = models.TextField('Contenu', help_text='Vous pouvez utiliser markdown')
  84. content_html = models.TextField('Contenu HTML', blank=True)
  85. creation_date = models.DateTimeField('Date de création')
  86. modification_date = models.DateTimeField('Date de modification')
  87. publication_date = models.DateTimeField('Date de publication', null=True, blank=True)</pre>
  88. <p>Il y a juste le manager dans lequel je suis en train d'intégrer les votes donc j'en parlerais probablement plus tard, je vais m'arrêter là sinon je publierais jamais ce billet :-).</p>
  89. <h2>Accès au code source</h2>
  90. <p>J'ai créé pour l'occasion un <a href="http://code.google.com/p/biologeek/">projet sur Google Code qui contient l'intégralité du code</a>. Vous pouvez facilement récupérer le code avec subversion&nbsp;:</p>
  91. <pre>svn checkout http://biologeek.googlecode.com/svn/trunk/ biologeek</pre>
  92. <p>Checkoutez, testez, participez&nbsp;!</p>