一般地,先创建出一个虚拟环境,在虚拟环境中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注册的