Open-source sample that explains how to create a Django Model. All commands used to code the project and also the relevant updates are listed below. For newcomers, Django is a high-level Python Web framework that encourages rapid development and clean, pragmatic design. Built by experienced developers, it takes care of much of the hassle of Web development, so you can focus on writing your app without needing to reinvent the wheel.
For support and more Django Samples join AppSeed.
Chech Python Version
$ python --version
Python 3.8.4 <-- All goodCreate/activate a virtual environment
$ # Virtualenv modules installation (Unix-based systems)
$ virtualenv env
$ source env/bin/activate
$
$ # Virtualenv modules installation (Windows-based systems)
$ # virtualenv env
$ # .\env\Scripts\activateInstall Django
$ pip install djangoCreate Django Project
$ mkdir django-create-model
$ cd django-create-modelInside the new directory, we will invoke startproject subcommand
django-admin startproject config .Note: Take into account that
.at the end of the command.
Setup database
$ python manage.py makemigrations
$ python manage.py migrateStart the app
$ python manage.py runserver Create sample app
$ python manage.py startapp sampleVisualize the default SQL settings - config/settings.py
# File: config/settings.py (partial content)
...
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.sqlite3',
'NAME': BASE_DIR / 'db.sqlite3',
}
}
...Define a new model Books in sample application. The below changes should be added to sample/models.py:
# File: sample/models.py
from django.db import models
class Book(models.Model): # <- NEW
title = models.CharField(max_length=100) # <- NEW
author = models.CharField(max_length=100) # <- NEW
publication_date = models.DateField() # <- NEW Update Project Configuration to use the new model - The sample application must be added in the project configuration to INSTALLED_APPS section.
# File: config/settings.py (partial content)
...
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'sample' # <- NEW
]
...Tip - for a quick check over latest changes we can run check subcommand.
$ python manage.py check
System check identified no issues (0 silenced). Generate the SQL code
$ python manage.py makemigrations # generate the SQL code
Migrations for 'sample':
sample\migrations\0001_initial.py
- Create model BookApply changes on database
$ python manage.py migrate
Operations to perform:
Apply all migrations: admin, auth, contenttypes, sample, sessions
Running migrations:
Applying sample.0001_initial... OKUse the model via CLI
Once the model is created we can use it via the Django shell
$ python manage.py shell
>>>
>>> from sample.models import Book # import the Book model in our context
>>> from django.utils import timezone # used to provide the value for publication_date
>>>
>>> book1 = Book(title='The Adventures of Tom Sawyer', author='Mark Twain', publication_date=timezone.now() )
>>> book1.save() # save the new bookList all books (using the CLI)
$ python manage.py shell
>>>
>>> from sample.models import Book
>>> Book.objects.all()
<QuerySet [<Book: Book object (1)>]>We can see our new book retuned by the query. Let's improve the information that describe the object.
Django Model - add text representation of an object
To achieve this goal, we should define the __str__() method for the Book model
# File: sample/models.py
from django.db import models
class Book(models.Model):
title = models.CharField(max_length=100)
author = models.CharField(max_length=100)
publication_date = models.DateField()
def __str__(self): # <- NEW
return self.title # <- NEWLet's restart the Django console and check the results:
$ python manage.py shell
>>>
>>> from sample.models import Book
>>> Book.objects.all()
<QuerySet [<Book: The Adventures of Tom Sawyer>]>Use the model via Admin Section
Django comes with an admin section our-of-the box that allows us to manage with ease all models defined in project.
To manage the Book model in the administration console we need to create a superuser (aka the admin) and after register the Book model to be visible in the admin section.
Create the superuser
$ python manage.py createsuperuser
sername (leave blank to use 'sm0ke'): admin
Email address: admin@appseed.us
Password:
Password (again):
Superuser created successfully.Register
Bookmodel to be visible in theadminsection - Editsample/admin.pyas below:
# File: sample/admin.py
from django.contrib import admin
from .models import Book # <- NEW
admin.site.register(Book) # <- NEWAuthenticate as admin -
http://localhost:8000/admin/
At this point we should see the Books model in the UI and able to execute CRUD operations.
For support and more Django Samples join AppSeed.
Create Model in Django - Open-source Sample provided by AppSeed.


