Taille: 6037
Commentaire: reformet puces et contenu
|
Taille: 6507
Commentaire:
|
Texte supprimé. | Texte ajouté. |
Ligne 7: | Ligne 7: |
* présenter data dans frontend | * présenter des données dans le frontend (interface publique) avec Django |
Ligne 12: | Ligne 12: |
* AUF : page wikiteki sur [[Django]] | |
Ligne 13: | Ligne 14: |
* Part 1 : créer un projet, créer une app, jouer avec ORM (API) ''convert en partie lors de atelier 2011-12-07'' * Part 2 : backend (admin) ''convert lors de atelier 2011-12-07'' * Part 3 : frontend _couvert ici, plus efficacement même ;)_ * Part 4 : forms et vues génériques _pas couvert ici_ |
* Part 1 : créer un projet, créer une app, jouer avec ORM (API) ''couvert en partie lors de atelier 2011-12-07'' * Part 2 : backend (admin) ''couvert lors de atelier 2011-12-07'' * Part 3 : frontend ''couvert ici, plus efficacement même ;)'' * Part 4 : forms et vues génériques ''pas couvert ici'' |
Ligne 36: | Ligne 37: |
Ligne 37: | Ligne 39: |
Ligne 47: | Ligne 50: |
=== Télécharger les sources initiales === Repartir du projet créé lors de l'atelier du 2011-12-07. |
=== Repartir des sources initiales === Repartir du projet créé lors de l'atelier du 2011-12-07 : sources initiales |
Ligne 58: | Ligne 62: |
* recrutement/urls.py https://docs.djangoproject.com/en/1.3/topics/http/urls/ |
* urls.py https://docs.djangoproject.com/en/1.1/topics/http/urls/ |
Ligne 62: | Ligne 66: |
* recrutement/views.py https://docs.djangoproject.com/en/1.3/topics/http/views/ _voir tutoriel Part 3 (version shortcut)_ https://docs.djangoproject.com/en/1.3/intro/tutorial03/ |
* views.py https://docs.djangoproject.com/en/1.1/topics/http/views/ ''voir tutoriel Part 3 (version shortcut)'' https://docs.djangoproject.com/en/1.1/intro/tutorial03/ |
Ligne 68: | Ligne 74: |
https://docs.djangoproject.com/en/1.3/topics/templates/ | https://docs.djangoproject.com/en/1.1/topics/templates/ |
Ligne 71: | Ligne 77: |
{{{ os.path.join(os.path.dirname(__file__), "templates"), |
{{{ |
Ligne 74: | Ligne 79: |
}}} * templates/recrutement/home.html * recrutement/views.py _passer une variable au template_ * templates/recrutement/home.html _utiliser une variable :_ {{{ |
TEMPLATE_DIRS = ( # Put strings here, like "/home/html/django_templates" or "C:/www/django/templates". # Always use forward slashes, even on Windows. # Don't forget to use absolute paths, not relative paths. os.path.join(os.path.dirname(__file__), "templates"), ) }}} * templates/home.html * views.py ''passer une variable au template'' * templates/home.html ''utiliser une variable :'' {{{ |
Ligne 86: | Ligne 97: |
* recrutement/views.py _endroit où on code en logique en Python plus simple si explore interactivement..._ {{{ |
* views.py ''endroit où on code la logique en Python...'' ''...plus simple si explore interactivement'' {{{ |
Ligne 94: | Ligne 106: |
* ORM (API) : object relation mapping {{{ from recrutement.models import * equipes = Equipe.objects.all() for e in equipes: print e e = equipes[0] e.joueur_set.all() j = Joueur.objects.get(id=1) j.id j = Joueur.objects.get(id=314) |
* ORM (API) : object relationnal mapping {{{ from etablissements.models import * etablissements = Etablissement.objects.all() for e in etablissements: print e e = etablissements[0] e.formation_set.all() f = Formation.objects.get(id=1) f.id f = Formation.objects.get(id=314) |
Ligne 105: | Ligne 117: |
joueurs = Joueur.objects.filter(equipe__nom__startswith='Pyth') }}} * recrutement/models.py {{{ related_name = "joueurs" |
formations = Formation.objects.filter(etablissement__nom__contains='Hanoi') }}} * etablissements/models.py {{{ related_name = "formations" |
Ligne 114: | Ligne 126: |
{{{ e.joueurs.all() e.joueurs.count() }}} * recrutement/views.py _passer les variables pertinentes pour accueil_ * templates/recrutement/home.html _boucle for dans template :_ {{{ {% for e in equipes %} |
{{{ e.formations.all() e.formations.count() }}} * views.py ''passer les variables pertinentes pour accueil'' * templates/home.html ''boucle for dans template :'' {{{ {% for e in etablissements %} |
Ligne 129: | Ligne 141: |
== PARTIE 3 : PROJET LIGUEMP PIMPÉ == Télécharger les sources du projet pimpé : http://montrealpython.org/r/attachments/8 Extraire (_sans clash de nom avec projet en cours_) |
== PARTIE 3 : PROJET CARTO PIMPÉ == Télécharger les sources finales du projet pimpé : sources finales |
Ligne 141: | Ligne 150: |
{{{ | {{{ |
Ligne 146: | Ligne 155: |
{{{ | {{{ |
Ligne 153: | Ligne 162: |
https://docs.djangoproject.com/en/1.3/howto/static-files/ | https://docs.djangoproject.com/en/1.1/howto/static-files/ |
Ligne 161: | Ligne 170: |
* STATICFILES_DIRS {{{ os.path.join(os.path.dirname(__file__), "static"), }}} * urls.py {{{ from django.contrib.staticfiles.urls import staticfiles_urlpatterns urlpatterns += staticfiles_urlpatterns() |
{{{ MEDIA_ROOT = os.path.join(os.path.dirname(__file__), 'media') MEDIA_URL = '/static/' }}} * urls.py {{{ from django.conf import settings if settings.DEBUG: urlpatterns += patterns('', (r'^static/(?P<path>.*)$', 'django.views.static.serve', {'document_root': settings.MEDIA_ROOT}), ) |
Ligne 183: | Ligne 196: |
{{{ | {{{ |
Ligne 190: | Ligne 203: |
* urls.py : import des urls de l'app recrutement * recrutement/urls.py * recrutement/views.py * templates/recrutement/* === Refactoring du home === * urls home dans views.py à la racine |
* urls.py : import des urls de l'app etablissements * etablissements/urls.py * etablissements/views.py * templates/etablissements/* |
Ligne 201: | Ligne 210: |
* recrutement/admin.py * classes JoueurAdmin, EquipeAdmin _héritent de ModelAdmin_ |
* etablissements/admin.py * classes EtablissementAdmin, FormationAdmin ''héritent de ModelAdmin'' |
Ligne 206: | Ligne 217: |
{{{ admin.site.register(Joueur, JoueurAdmin) |
{{{ admin.site.register(Formation, FormationAdmin) |
Ligne 210: | Ligne 221: |
{{{ | {{{ |
Ligne 215: | Ligne 226: |
* plus? https://docs.djangoproject.com/en/1.3/ref/contrib/admin/ |
* plus? https://docs.djangoproject.com/en/1.1/ref/contrib/admin/ |
Ligne 222: | Ligne 232: |
https://docs.djangoproject.com/en/1.3/ref/django-admin/ | https://docs.djangoproject.com/en/1.1/ref/django-admin/ |
Ligne 225: | Ligne 235: |
{{{ |
{{{ |
Ligne 233: | Ligne 242: |
{{{ | {{{ |
Ligne 239: | Ligne 248: |
== PARTIE 4 : HANDS-ON : CRÉER L'APPLICATION SAISON POUR LE PROJET LIGUEMP == === Ajouter modèle Match === |
== PARTIE 4 : HANDS-ON : CRÉER L'APPLICATION PROJET POUR LE PROJET CARTO == === Ajouter modèle Projet === |
Ligne 244: | Ligne 253: |
* date * lieu * equipe1 * equipe2 * score1 * score2 === Autre exercice : age d'un joueur === * Joueur.date_naissance * Joueur.age() _ajouter une methode age() sur la classe Joueur utilisant la date de naissance_ |
* nom * date_debut * date_fin * etablissements === Autre exercice : durée d'un Projet et avancement d'un Projet === * Projet.duree() {{{ """Durée prévue en fonction des dates de début et de fin""" }}} * Projet.avancement() {{{ """Durée réelle à partir de la date de début jusqu'à maintenant.""" }}} |
Ligne 268: | Ligne 280: |
http://groups.google.com/group/django-users | http://groups.google.com/group/django-users |
Ligne 271: | Ligne 283: |
irc://irc.freenode.net/django | irc://irc.freenode.net/django |
Ligne 274: | Ligne 286: |
https://docs.djangoproject.com/en/dev/ref/contrib/ | https://docs.djangoproject.com/en/dev/ref/contrib/ |
Ligne 278: | Ligne 290: |
http://pypi.python.org/ | http://pypi.python.org/ |
Atelier 2011-12-12 : Plan détaillé
INTRODUCTION
- Objectifs
- connaître l'architecture d'un projet : principaux fichiers
- présenter des données dans le frontend (interface publique) avec Django
- Documentation
- doc : bonne version de django
officielle : https://docs.djangoproject.com/en/1.1/
français : http://docs.django-fr.org/
AUF : page wikiteki sur Django
- tutoriel
Part 1 : créer un projet, créer une app, jouer avec ORM (API) couvert en partie lors de atelier 2011-12-07
Part 2 : backend (admin) couvert lors de atelier 2011-12-07
Part 3 : frontend couvert ici, plus efficacement même ;)
Part 4 : forms et vues génériques pas couvert ici
- doc : bonne version de django
- Environnement technique
Python >= 2.5
- Django 1.1.1
- Mac OS X : voir tutoriel Part 1 pour manip supplémentaire
PARTIE 1 : RAPPELS
Django
Principaux fichiers
- models.py
- admin.py
- urls.py
- views.py
- templates (HTML)
Projet carto : définition du besoin
L'AUF veut procéder à la cartographie de ses établissements membres.
On veut savoir quelle formation est donnée où...
... et répertorier les projets des membres.
Projet carto : modélisation
- Etablissement
- Formation
- Projet
PARTIE 2 : HANDS-ON : PROJET ET APPLICATIONS
Repartir des sources initiales
Repartir du projet créé lors de l'atelier du 2011-12-07 : sources initiales
Nous avions alors :
- Créé le projet carto
- Créé l'application etablissements
- Créé les modèles Etablissement et Formation
- Géré dans l'admin des Etablissements et des Formations
Frontend : présenter les données
- urls.py
https://docs.djangoproject.com/en/1.1/topics/http/urls/
- home
- views.py
https://docs.djangoproject.com/en/1.1/topics/http/views/
voir tutoriel Part 3 (version shortcut)
- templates
https://docs.djangoproject.com/en/1.1/topics/templates/
- créer répertoire templates
- settings.py
import os TEMPLATE_DIRS = ( # Put strings here, like "/home/html/django_templates" or "C:/www/django/templates". # Always use forward slashes, even on Windows. # Don't forget to use absolute paths, not relative paths. os.path.join(os.path.dirname(__file__), "templates"), )
- templates/home.html
- views.py
passer une variable au template
- templates/home.html
utiliser une variable :
{{ var }}
- views.py
endroit où on code la logique en Python...
...plus simple si explore interactivement
python manage.py shell
- ORM (API) : object relationnal mapping
from etablissements.models import * etablissements = Etablissement.objects.all() for e in etablissements: print e e = etablissements[0] e.formation_set.all() f = Formation.objects.get(id=1) f.id f = Formation.objects.get(id=314) e.id formations = Formation.objects.filter(etablissement__nom__contains='Hanoi')
- etablissements/models.py
related_name = "formations"
- relancer shell
e.formations.all() e.formations.count()
- views.py
passer les variables pertinentes pour accueil
- templates/home.html
boucle for dans template :
{% for e in etablissements %} {% endfor %}
PARTIE 3 : PROJET CARTO PIMPÉ
Télécharger les sources finales du projet pimpé : sources finales
Pimpé? Quoi de neuf?
Héritage de templates
- base.html
{% block main %}
- templates
{% extends "base.html" %} {% block main %}
Fichiers statiques : CSS, images et js
https://docs.djangoproject.com/en/1.1/howto/static-files/
- répertoire : static
- css
- images
- js
- settings.py
MEDIA_ROOT = os.path.join(os.path.dirname(__file__), 'media') MEDIA_URL = '/static/'
- urls.py
from django.conf import settings if settings.DEBUG: urlpatterns += patterns('', (r'^static/(?P<path>.*)$', 'django.views.static.serve', {'document_root': settings.MEDIA_ROOT}), )
Connexion du user
- templates
- connexion.html
- deconnexion.html
- urls.py
- connexion
- deconnexion
- settings.py
LOGIN_REDIRECT_URL = "/"
URL avec paramètres
- pages de détail : capter l'id de l'objet
- urls.py : import des urls de l'app etablissements
- etablissements/urls.py
- etablissements/views.py
- templates/etablissements/*
Admin pimpé : ModelAdmin
- etablissements/admin.py
classes EtablissementAdmin, FormationAdmin
héritent de ModelAdmin
enregistrer Modele avec ModeleAdmin
admin.site.register(Formation, FormationAdmin)
config ModeleAdmin
list_display search_fields list_filter
plus? https://docs.djangoproject.com/en/1.1/ref/contrib/admin/
- fields
- fieldsets
Charger données initiales : fixtures
https://docs.djangoproject.com/en/1.1/ref/django-admin/
- créer répertoire fixtures à la racine
python manage.py dumpdata > initial_data.json
- mettre initial_data.json dans fixtures
- pour récupération data :
python manage.py syncdb no (pas créer user) python manage.py loaddata fixtures/initial_data.json
PARTIE 4 : HANDS-ON : CRÉER L'APPLICATION PROJET POUR LE PROJET CARTO
Ajouter modèle Projet
- Projet
- nom
- date_debut
- date_fin
- etablissements
Autre exercice : durée d'un Projet et avancement d'un Projet
- Projet.duree()
"""Durée prévue en fonction des dates de début et de fin"""
- Projet.avancement()
"""Durée réelle à partir de la date de début jusqu'à maintenant."""
CONCLUSION : POUR CONTINUER
- Autres aspects non couverts (quelques uns)
- permissions et décorateurs
- manage.py inspectdb
- manage.py test
- forms
- generic views
- templates : tags, filtres
- Mailing list Django users :
- Channel IRC #django :
- Contribs, plugins
https://docs.djangoproject.com/en/dev/ref/contrib/
- south
- reversion
- Autre : pypi
- Enjoy!