django创建app基本流程

一般地,先创建出一个虚拟环境,在虚拟环境中pip安装django,用==指定版本,之后用django-admin startproject mysite创建一个项目,之后python manage.py startapp myapp创建一个app,进入settings中修改项目时区与语言

LANGUAGE_CODE = 'zh-Hans'

TIME_ZONE = 'Asia/Shanghai'

修改这两项
在app视图中导入from django.http import HttpResponse
为视图添加函数之后在app里面添加一个urls.py文件

from django.urls import path

from . import views

导入视图和path模块

urlpatterns = [
    path('',views.index,name='index')   #此处name别名可以用于网页中来获取url
]

再修改project的urls,在path后面添加include

from django.contrib import admin
from django.urls import path,include

urlpatterns = [
    path('admin/', admin.site.urls),
    path('polls/',include('polls.urls'))
]

将app以appname.apps.AppnameConfig的形式添加入settings,然后在app的models中创建模型,一个类即代表数据库中的一张表,类名即是表名,对大小写不敏感,然后执行python manage.py migrate
再执行python manage.py makemigrations appname即可完成迁移

python manage.py sqlmigrate polls 0001

可查看对应的迁移所使用的SQL语句,由此可以看出数据库的表名是由我们编写的app的名字加上在models中的类的名字的小写形式组成的

-- Create model Question
--
CREATE TABLE "polls_question" ("id" integer NOT NULL PRIMARY KEY AUTOINCREMENT, 
"question_text" varchar(200) NOT NULL,
 "pub_date" datetime NOT NULL);
--
-- Create model Choice
--
CREATE TABLE "polls_choice" ("id" integer NOT NULL PRIMARY KEY AUTOINCREMENT, 
"choice_text" varchar(200) NOT NULL, 
"votes" integer NOT NULL, 
"question_id" integer NOT NULL REFERENCES "polls_question" ("id") DEFERRABLE INITIALLY DEFERRED);
CREATE INDEX "polls_choice_question_id_c5b4b260" ON "polls_choice" ("question_id");
COMMIT;

在views中context = {'question':question}字符串的question是在网页中显示的{{ question }}

在管理网站注册app

from django.contrib import admin

from .models import Question

admin.site.register(Question)

这是在app里面的admin注册的

你可能感兴趣的:(python)