I modelli di Django
Vogliamo creare un qualcosa che raccoglierà tutti i post del nostro blog. Per farlo, però, dobbiamo prima introdurre i cosiddetti oggetti
.
Oggetti
Esiste un concetto nella programmazione che è quello di programmazione orientata agli oggetti
. L'idea di base è che invece di scrivere una noiosa sequenza di istruzioni di programmazione, possiamo modellare le cose e decidere come devono interagire l'una con l'altra.
Quindi cos'è un oggetto? È un insieme di proprietà ed azioni. Suona strano, ma ti faremo un esempio.
Se vogliamo il modello di un gatto creeremo un oggetto Gatto
che possiede alcune proprietà come: colore
, età
, umore
(come buono, cattivo, assonnato ;) ) e padrone
(che è un oggetto Persona
oppure, nel caso di un gatto randagio, la proprietà sarà vuota).
Quindi il Gatto
possiede anche alcune azioni: fare_le_fusa
, graffiare
e alimentare
(in quest'ultimo caso, daremo al gatto del CiboPerGatti
, che sarà un altro oggetto con le sue proprietà, come gusto
).
Cat
--------
color
age
mood
owner
purr()
scratch()
feed(cat_food)
CatFood
--------
taste
Quindi in pratica l'idea è quella di descrivere cose vere in codice con delle proprietà (chiamate proprietà di oggetti
) e azioni (chiamate metodi
).
Quindi come faremo a modellare i post del blog? vogliamo costruire un blog, giusto?
Dobbiamo rispondere alla domanda: cos'è un post? Quali proprietà dovrebbe avere?
Beh, sicuramente il nostro post ha bisogno di qualche testo con il suo contenuto ed un titolo, vero? Sarebbe bello sapere anche chi l'ha scritto - quindi abbiamo bisogno di un autore. Infine, vogliamo sapere quando il post è stato creato e pubblicato.
Post
--------
titolo
testo
autore
data_creazione
data_pubblicazione
Che tipo di cose si potrebbero fare con un post? Sarebbe bello avere qualche metodo
che pubblica il post, vero?
Quindi avremo bisogno di un metodo pubblicare
.
Dal momento che sappiamo già cosa vogliamo ottenere, iniziamo a modellarlo in Django!
Modello Django
Sapendo cos'è un oggetto, possiamo creare un modello Django per il nostro post.
Un modello in Django è uno speciale tipo di oggetto - è salvato nel database
. Un database è un insieme di dati. È un posto in cui archivierai informazioni sui tuoi utenti, sui tuoi post, ecc. Useremo un database SQLite per archiviare i nostri dati. Questo è l'adattatore Django di database predefinito -- ci basterà per adesso.
Puoi pensare ad un modello nel database come ad un foglio elettronico con colonne (campi) e righe (dati).
Creazione di un'applicazione
Per mantenere tutto ordinato, creeremo un'applicazione diversa all'interno del nostro progetto. E' molto bello avere tutto organizzato fin dall'inizio. Per creare un'applicazione abbiamo bisogno di eseguire il seguente comando nella console (dalla cartella djangogirls
dove si trova il file manage.py
):
Mac OS X o Linux:
(myvenv) ~/djangogirls$ python manage.py startapp blog
Windows:
(myvenv) C:\Users\Name\djangogirls> python manage.py startapp blog
Noterai che si è creata una nuova cartella blog
e che ora contiene alcuni file. Le nostre cartelle ed i nostri file nel nostro progetto si dovrebbero vedere così:
djangogirls
├── blog
│ ├── admin.py
│ ├── apps.py
│ ├── __init__.py
│ ├── migrations
│ │ └── __init__.py
│ ├── models.py
│ ├── tests.py
│ └── views.py
├── db.sqlite3
├── manage.py
├── mysite
│ ├── __init__.py
│ ├── settings.py
│ ├── urls.py
│ └── wsgi.py
├── myvenv
│ └── ...
└── requirements.txt
Dopo aver creato un'applicazione dobbiamo dire a Django che dovrebbe utilizzarla. Lo facciamo nel file mysite/settings.py
-- aprilo nell'editor di codice. Dobbiamo scoprire INSTALLED_APPS
ed aggiunge una riga contenente 'blog.apps.BlogConfig',
proprio sopra ]
. Il progetto dovrebbe assomigliare a questo:
mysite/settings.py
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'blog.apps.BlogConfig',
]
Creazione di un modello blog post
Nel file blog/models.py
definiamo tutti gli oggetti chiamati Models
- Questo è il posto dove definiremo il nostro blog post.
Apriamo blog/models.py
, cancella tutto quello che è lì e scrivi un codice come questo:
blog/models.py
from django.conf import settings
from django.db import models
from django.utils import timezone
class Post(models.Model):
author = models.ForeignKey(settings.AUTH_USER_MODEL, on_delete=models.CASCADE)
title = models.CharField(max_length=200)
text = models.TextField()
created_date = models.DateTimeField(default=timezone.now)
published_date = models.DateTimeField(blank=True, null=True)
def publish(self):
self.published_date = timezone.now()
self.save()
def __str__(self):
return self.title
Assicurati di aver usato 2 underscore (
_
) da entrambi i lati distr
. Questa convenzione viene utilizzata spesso in Python e a volte li chiamiamo anche "dunder" (abbreviazione di "doppio carattere di sottolineatura").
Sembra spaventoso, vero? ma non ti preoccupare, ti spiegheremo cosa significano queste righe!
Tutte le righe che iniziano con from
oppure con import
sono righe che aggiungono alcuni pezzi da altri file. Quindi invece di copiare e incollare le stesse cose in ogni file, possiamo includere alcune parti con from ... importa ...
.
class Post(models.Model):
- questa riga definisce il nostro modello (è un oggetto
).
class
è una parola chiave speciale che indica che stiamo definendo un oggetto.Post
è il nome del nostro modello. Possiamo dargli un nome diverso (ma dobbiamo evitare caratteri speciali e spazi). Inizia sempre il nome di una classe con un lettera maiuscola.models.Model
significa che il Post è un modello Django, quindi Django sa che dovrebbe essere salvato nel database.
Ora definiamo le proprietà di cui stavamo parlando: titolo
, testo
, data_creazione
, data_pubblicazione
e autore
. Per fare ciò dobbiamo definire un tipo per ogni campo (è un testo? Un numero? Una data? Una relazione con un altro oggetto, come User?)
models.CharField
- così si definisce un testo con un numero limitato di lettere.models.TextField
- questo è il codice per definire un testo senza un limite. Sembra l'ideale per i contenuti di un post, vero?models.DateTimeField
- questo per la data ed l'ora.models.ForeignKey
- questo è un link a un altro modello.
Non spiegheremo ogni pezzo di codice perchè ci vorrebbre troppo tempo. Dovresti dare un'occhiata alla documentazione di Django se vuoi sapere di più sui campi del Modello e come definire le cose oltre che da quelli descritti sopra (https://docs.djangoproject.com/en/2.2/ref/models/fields/#field-types).
Che dire di def publish(self):
? È esattamente il metodo pubblicare
di cui stavamo parlando prima. def
significa che questa è una funzione/metodo e publish
è il nome del metodo. Puoi modificare il nome del metodo, se vuoi. La regola per la denominazione è usare lettere minuscole e caratteri di sottolineatura al posto degli spazi. Per esempio, un metodo che calcola il prezzo medio potrebbe essere chiamato calculate_average_price
.
I metodi spesso restituiscono
qualcosa. C'è un esempio nel metodo __str__
. In questo caso, quando chiamiamo __str__()
otterremo un testo (stringa) con il titolo del Post.
Nota anche che entrambe def publish(self):
e def __str__(self):
sono indentate all'interno della classe. Poiché Python è sensibile agli spazi, dobbiamo indentare i nostri metodi dentro alla classe. Altrimenti i metodi non apparterranno alla classe e potresti ottenere qualche comportamento inaspettato.
Se c'è qualcosa di poco chiaro sui modelli, sentiti libera/o di chiedere al tuo coach! Sappiamo che è complicato, soprattutto quando impari cosa sono gli oggetti e le funzioni allo stesso tempo. Ma speriamo che sembri un po' meno magico per te per adesso!
Crea tabelle per i modelli nel tuo database
L'ultimo passo è quello di aggiungere un nuovo modello al nostro database. Prima dobbiamo far sapere a Django che ci sono alcuni cambiamenti nel nostro modello (l'abbiamo appena creato. (Vai alla finestra della tua console e digita python manage.py makemigrations blog
. Il risultato somiglierà a questo:
command-line
(myvenv) ~/djangogirls$ python manage.py makemigrations blog
Migrations for 'blog':
blog/migrations/0001_initial.py:
- Create model Post
Nota: Ricorda di salvare i file che modifica. Altrimenti, il computer eseguirà la versione precedente che potrebbe fornirti messaggi di errore inattesi.
Django ci ha preparato un file di migrazione che dobbiamo applicare nel nostro database. Digita python manage.py migrate blog
e l'output dovrebbe essere:
command-line
(myvenv) ~/djangogirls$ python manage.py migrate blog
Operations to perform:
Apply all migrations: blog
Running migrations:
Applying blog.0001_initial... OK
Evviva! Il nostro modello Post ora è nel database! Sarebbe bello poterlo vedere, vero? Vai al prossimo capitolo per vedere com'è il tuo Post!