This is the ninth day of my participation in the August More text Challenge. For details, see: August More Text Challenge

Django 是一款 Python web 开发框架,如何形容它 我们可以看下官方给的定义:Django makes it easier to build better Web apps more quickly and with less code.

Django makes building better Web applications easier and with less code.

Django origin

The Django framework was developed by Adrian Holovaty and Simon Willison, engineers at World Company in the US, to develop the news sites their Company runs (LJWorld.com, Lawrence.com, KUsports.com). In the process, it was gradually perfected and enriched, and opened source in 2005. It is by far the most well-known Web framework in Python.

The word Django comes from the Gypsy language with a silent “D”. In Chinese, it is usually translated as “Django”, although some people call it “Johnny” rather funnily

The Django framework takes its name from 1930s French jazz guitarist Django Reinhardt — one of the greatest guitarists ever, despite having only three fingers on his left hand

The characteristics of the Django

  1. Well-documented (http://python.usyiyi.cn)
  2. Database Access Component (ORM)
  3. URL mapping technology
  4. Built-in management interface (admin)
  5. Debugging information integrity

Django architecture

  1. Management: A command-line tool for creating sites, migrating data, and maintaining static files
  2. Model: Provides data access interfaces and modules, including the definition and operation of data fields, data relationships
  3. View: Used to return specific Web page data content to the user
  4. Templates :Django has its own page rendering Template language, making it easier for developers to customize how pages are generated
  5. Forms :Django can generate HTML forms using field properties in a Model

Development environment construction

  1. Python Windwos: Download the installation file from the Python official website

    Add Paython 3.x to path must be checked, otherwise PIP will not be opened

    There is no need to install Python for MAC and Linux

  2. Django: Install Django using the Python package management tool PIP. PIP install Django ==1.8.2

>>> import Django >>> print(django.get_version()) 1.8Copy the code

Create the first project

Django-admin startProject pro_1 will create a folder for pro_1 in the specified directory. Let’s read the directory structure

Pro_1 -----pro_1 # Container folder for the entire project, Py # This file tells Python that this directory is a package -------settings.py # Configuration/Settings for the Django project -------urls.py # Total routing management file for the Django project -------wsgi.py # a compatible Web server entry to use when a project is running and publishing -----manage.py # a useful command-line tool that allows us to interact with Django projects in various waysCopy the code

Django development mode: MVT mode

To better understand MVT, let’s first take a look at MVC. MVC consists of (attempt View/ Controller/ Model Model). In our practical application, the Model is used to process the application data logic, and the View (V) is used to process the data we take from M. The controller (C) defines the program behavior and selects the appropriate view

MVC framework is found in most development languages. The core idea of MVC framework is to decouple, reduce the coupling between functional modules, facilitate changes, and facilitate code refactoring to maximize code reuse

MVT is based on MVC, and makes a finer division on the basis of MVC. The main difference is C and T. C used to be a controller, but now it becomes a Template, integrating C into the View. MVT patterns include: Attempts (Views) take care of the business logic and, where appropriate, call models and Templates (templates), which take care of how the pages are presented to the user Model (Models) to process the application data logic

A Complete Django Project – Part 1 (Base + Model)

With that in mind, let’s start with a complete project using Django (in this case, the official voting application)

1. Create the project Django-admin startProject mysite

2. Configure the setting.py database

By default SQLite is used. You don’t need to install anything else. SQLite is included in Python and can be configured in database Binding for other databases if you want (we used SQLite for this project).

# default writing after creating the project DATABASES = {' default ': {' ENGINE' : 'the django. Db. Backends. Sqlite3', 'NAME' : OS. The path. The join (BASE_DIR, 'db. Sqlite3'),}} # for the modified ENGINE to django. Db. Backends. Mysql ' 'or' django. Db. Backends. Oracle 'Copy the code

3. Start the server

Now that we know the structure of the project, let’s verify that the Django project runs python manage.py RunServer

Next, open your browser and type http://127.0.0.1:8000/

When you see an effect like the one shown above, it will be executed. If your 8000 is occupied, you can specify a port python manage.py RunServer 8080

4. Create an application

Project already has, we need to start processing, we need to create a specific application to complete, project is similar to a large folder, and application is a specific file, a project can contain N applications, an application can also be applied to multiple projects is the reason

To create the application, note that our directory is still in the project directory:

python manage.py startapp polls

After the directory is created, the following directory structure is generated:

polls/
    __init__.py
    admin.py
    migrations/
          __init__.py
    models.py
    tests.py
    views.py
Copy the code

5. Create the model

The Django model corresponds to the database design. The database also has its own SQL statements. If you don’t know how the database statements operate on the database, this is what the Django model does. All we have to do is write Python code, and Django will translate the Python code into the appropriate database manipulation language.

Requirements: To analyze the voting application, we will create two models: Question and Choice. The Question object has a question_TEXT property and a publish_date property.

Choice has two fields: the content of the Choice and the vote count for the Choice. Each Choice is associated with a Question.

The model code is written in the polls/models.py file

from django.db import models class Question(models.Model): #CharField to represent a string, Question_text = models.CharField(max_length=200) #DateTimeField pub_date = models.DateTimeField('date published') class Choice(models.Model): #ForeignKey = models.foreignkey (question) choice_text = models.charfield (max_length=200) Votes = models.IntegerField(default=0)Copy the code

More data types can see https://docs.djangoproject.com/en/1.10/ref/models/fields/ website document

6. Perform migration operations

We’ve written the database model code for the voting application, but we haven’t actually created the database because this is just Python code that needs to be translated into databa-aware code through Django to execute.

When this is done, Django automatically does two things:

1. Create a database table for the application (create table statement)

2. Create a Python API to access the database

So the first thing we’re going to do is tell the polls app that we’ve created, to open the settings.py file, and change INSTALLED_APPS

INSTALLED_APPS = (
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'polls'
)
Copy the code

Next we execute Python manage.py makemighoisting polls

Executing makemignames tells Django what changes have been made to the model. When Django receives this information, it produces a 0001_initial.py file under migrations

# -* -coding: utf-8 -*- from __future__ import unicode_literals from django.db import models, migrations class Migration(migrations.Migration): dependencies = [ ] operations = [ migrations.CreateModel( name='Choice', fields=[ ('id', models.AutoField(verbose_name='ID', primary_key=True, serialize=False, auto_created=True)), ('choice_text', models.CharField(max_length=200)), ('votes', models.IntegerField(default=0)), ], ), migrations.CreateModel( name='Question', fields=[ ('id', models.AutoField(verbose_name='ID', primary_key=True, serialize=False, auto_created=True)), ('question_text', models.CharField(max_length=200)), ('pub_date', models.DateTimeField(verbose_name='date published')), ], ), migrations.AddField( model_name='choice', name='question', field=models.ForeignKey(to='polls.Question'), ), ]Copy the code

If you are familiar with database SQL statements, you can use the following command to see what Django does for you

python manage.py sqlmigrate blog 0001

If you don’t know SQL, you can skip this section. If you do know SQL, you will notice that the generated statement is different from what we defined.

  • The table name is automatically generated, using the app name polls combined with the lower-case letters of the model name — Question and Choice
  • The primary key (ID) is added automatically. (You can also rewrite this behavior.)
  • By convention, Django adds “_id” to the field names of foreign keys. (Yes, you can still rewrite this behavior.)
  • FOREIGN KEY relationships are explicitly declared by FOREIGN KEY constraints. Never mind the DEFERRABLE part; It simply tells PostgreSQL not to execute the foreign key association until the end of the transaction.
  • The SQLMigrate command doesn’t actually run the migrated files on your database — it just prints the SQL Django thinks it needs on the screen so you can see it.

The next step is critical, because the database has not been created yet. Python manage.py migrate the process of executing python manage.py migrations is to check the files that have just been generated under migrations to see what we need to do with the data

The migrate command will find all migrated files that have not yet been applied (Django uses a special table in the database called django_migrations to keep track of which migrations have been applied) and run them on your database — essentially, Synchronize your database schema with your changed model.

Migration is a powerful feature that allows you to constantly modify your model during development without having to delete a database or table and then regenerate a new one – it focuses on upgrading your database without losing data

The three steps of model change:

  • Modify your model (inmodels.pyIn the file).
  • runpython manage.py makemigrationsTo create a migration file for these changes
  • runpython manage.py migrateTo update the changes to the database

7. Use the Django API to operate the database

python manage.py shell

Once you have your data model set up, Django automatically generates a database abstraction API for you that lets you create, retrieve, update, and delete objects.

  • Add data

  • Query data

As if to see what the content of the query is, let’s modify the Models

class Question(models.Model):
    question_text = models.CharField(max_length=200)
    pub_date = models.DateTimeField('date published')
    def __str__(self):
        return self.question_text
Copy the code

Let’s look at the query again

  • Modify the data

  • Delete the data

Of course, in addition to the above listed basic add, delete, modify and check operations, other methods can see the official website

https://docs.djangoproject.com/en/1.10/ref/models/querysets/

A Complete Django Project – Part 2 (Admin Background)

The Django Admin backend

Django automatically generates an admin background based on the model file abbreviated above. Normally, the admin background is used by webmasters. To access the admin background, you first need to create a super administrator account by running the Python manage.py createsuperuser command

One big hole in this area for people who haven’t used Linux before is that when you type in your password, it doesn’t show up

Next we start the development server python manage.py RunServer

Open a browser to http://127.0.0.1:8000/admin/

After you enter the account and password you just entered, the operation interface is as follows:

These are provided by Django.contrib. auth. The authentication framework is integrated into Django. How can we configure our own applications to be edited as well

Open the amdin. Py

from django.contrib import admin
from .models import Question,Choice
# Register your models here.
admin.site.register(Question)
admin.site.register(Choice)
Copy the code

Then you can operate through the management background

A Complete Django Project – Part 3 (Views)

The interaction process of Web references is really the process of HTTP request and response

In Django, the pages and other content of a WEB page are delivered by views that respond to WEB requests. Each view is represented by a simple Python function (or a class-based view-based method). Django selects which view to use by examining the requested URL (specifically, the portion of the URL after the domain name).

In our voting application, we will have the following four views:

  1. Question home page – Displays the newly released questions.
  2. Question “Details” page – Displays the details of a single Question, and instead of showing the current voting results for that Question, provides a form for voting.
  3. Question “Results” page – Displays the vote results for a particular Question.
  4. Vote function – Handles the vote on Choice in Question.

Write the views and enter them in the views.py file

from django.http import HttpResponse
def index(request):
    return HttpResponse("Hello, world. You're at the polls index.")
Copy the code

To be able to call a view, we need to map the view to a URL, so we create a urls.py configuration under the polls folder

from django.conf.urls import url
from . import views
urlpatterns = [
    url(r'^$', views.index, name='index'),
]
Copy the code

Next, we need to configure from the main urls.py

# pit points: Urlpatterns = [URL (r'^admin/', include(admin.site.urls))), URL (r'^polls/', include(' params '))),]Copy the code

Visit http://127.0.0.1:8000/polls/ to see the page output the Hello, world. You ‘r e at the polls index.

This place configures the URL with four parameters:

  1. Regex (required): Regex means the syntax for a ‘regular expression’ to match a pattern in a string, in this case a url
  2. View (required) : When Django finds a successful match, it calls the view function specified by the view argument, with an HttpRequest object as the first argument
  3. Kwargs (optional) : Any keyword argument can be passed to the target view as a dictionary
  4. Name (optional) names your URL, which you can reference explicitly in Django by name

So let’s write a view with arguments and let’s start by modifying views.py

from django.http import HttpResponse def index(request): return HttpResponse("Hello, world. You're at the polls index.") def detail(request, question_id): return HttpResponse("You're looking at question %s." % question_id) def results(request, question_id): response = "You're looking at the results of question %s." return HttpResponse(response % question_id) def vote(request,  question_id): return HttpResponse("You're voting on question %s." % question_id)Copy the code

Modify the polls/urls. Py

urlpatterns  = [
     # ex: /polls/
         url(r'^$', views.index, name='index'),
         # ex: /polls/5/
         url(r'^(?P<question_id>[0-9]+)/$', views.detail, name='detail'),
         # ex: /polls/5/results/
         url(r'^(?P<question_id>[0-9]+)/results/$', views.results, name='results'),
         # ex: /polls/5/vote/
         url(r'^(?P<question_id>[0-9]+)/vote/$', views.vote, name='vote'),
]
Copy the code

To see if I can capture http://127.0.0.1:8000/polls/21/ to our parameters


So this is a fancy dividing line, and it’s all about the side dishes of the view, and now it’s time to get into the view, we need the view to display the data and how do we do that

HTTP import HttpResponse from. Models import Question def index(request): latest_question_list = Question.objects.order_by('-pub_date')[:5] output = ', '.join([p.question_text for p in latest_question_list]) return HttpResponse(output)Copy the code

Visit http://127.0.0.1:8000/polls/ could be seen in the Admin add background data

A Complete Django Project – Part 4 (Templates)

The data from the view above, is the page ugly? The ugly

How can we change the look of the page? Django provides a template system that separates the design of the page from Python by creating a template that the view can call. First, go to the polls directory and create a “templates” file. Django will look for polls here. For better reuse, go to the “templates” folder and create the “index. HTML” directory: polls/templates/polls/index.html

Insert the code in index.html

{% if latest_question_list %} <ul> {% for question in latest_question_list %} <li><a href="/polls/{{ question.id }}/">{{  question.question_text }}</a></li> {% endfor %} </ul> {% else %} <p>No polls are available.</p> {% endif %}Copy the code

Modify views. Py

from django.http import HttpResponse
from django.template import RequestContext, loader
from .models import Question
def index(request):
    latest_question_list = Question.objects.order_by('-pub_date')[:5]
    template = loader.get_template('polls/index.html')
    context = RequestContext(request, {
        'latest_question_list': latest_question_list,
    })
    return HttpResponse(template.render(context))
Copy the code

Let’s run this again, point your browser to ‘/polls’ to load the page, and you’ve got the page style

If the above code is too tedious, we can modify views.py

from django.shortcuts import render

from .models import Question


def index(request):
    latest_question_list = Question.objects.order_by('-pub_date')[:5]
    context = {'latest_question_list': latest_question_list}
    return render(request, 'polls/index.html', context)
Copy the code

The render() function takes the request object as its first argument, the name of the template as its second argument, and a dictionary as its optional third argument. It returns an HttpResponse object containing the template rendered with the given context.

Now to deal with the details of the page views, first create the detail. HTML (polls/templates/polls/detail. The HTML page insert content

<h1>{{ question.question_text }}</h1> <ul> {% for choice in question.choice_set.all %} <li>{{ choice.choice_text }}</li>  {% endfor %} </ul>Copy the code

Handle the detail under views.py

def detail(request, question_id):
    try:
        question = Question.objects.get(pk=question_id)
    except Question.DoesNotExist:
        raise Http404("Question does not exist")
    return render(request, 'polls/detail.html', {'question': question})

Copy the code

List when you visit http://127.0.0.1:8000/polls/ click on the title page can be either to see details, the style of the page and I was not a lot of CSS, style part we can replenish themselves