创建一个 Django 项目与一个应用程序
django-admin startproject webtest
cd webtest
python manage.py startapp book
在生成的webtest/webtest/init.py文件下添加
import pymysql
pymysql.install_as_MySQLdb()
打开 settings.py 文件,修改 INSTALLED_APPS 以完成对应用的配置
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'book'
]
创建一个数据库,数据库protest必须先存在才能使用
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'protest',
'HOST':'localhost',
'USER':'root',
'PASSWORD':'123456789',
'PORT':3306
}
}
启动服务 如果不加IP和端口号,url默认127.0.0.1 端口号为8000
pythonmanage.pyrunserver
,打开浏览器并在地址栏输入 http://127.0.0.1:8000,显示如下效果则表示成功
定义与创建模型
设计并生成数据表 生成的数据表名称默认为 应用名_类名, 如果想修改名称可在类的下面在建立一个类Meta, 执行verbose_name_plural=“表名” 对表名进行修改
from django.db import models
class BookInfo(models.Model):
bname = models.CharField("书名",max_length=20)
bpub_date = models.DateField("出版日期")
bpage = models.IntegerField(verbose_name='总页数',default=0)
is_delete=models.BooleanField(default=False)
def __str__(self):
return self.bname + "," + str(self.bpub_date) + "," + str(self.bpage)
class AuthorInfo(models.Model):
aname = models.CharField("姓名",max_length=10)
agender = models.BooleanField(verbose_name='性别', default=True)
acontent = models.CharField(verbose_name='简介', max_length=200)
abook = models.ForeignKey('BookInfo', verbose_name='相关书籍')
is_delete=models.BooleanField(default=False)
def __str__(self):
return self.aname
生成数据表,则需要先执行如下命令用于生成迁移文件和执行迁移文件
python manage.py makemigrations
pythonmanage.pymigrate
添加数据,可就直接到MySQL下直接添加数据,也可在python脚本下添加数据,以下是直接在MySQL下添加数据的代码 向book_bookinfo添加数据
insert into book_bookinfo(bname,bpub_date,bpage,is_delete) values ("Python 从入门到精通","2017-6-3",431,0),
("Python 经典案例 100 例","2018-9-7",154,0),
("疯狂的程序员","2007-3-4",310,0);
向book_authorinfo添加数据
insert into book_authorinfo(aname,agender,acontent,is_delete,abook_id)
values ("李军",1,"实战开发",0,1),
("叶维忠",1,"大学教授",0,1),
("方哥",1,"实战开发",0,2),
("叶子美",0,"大学讲师",0,2),
("绝影",1,"博客博主",0,3);
图书信息显示
通过访问“http://127.0.0.1:8000/index”展示出数据。首先,找到 webtest/ webtest 目录下的 urls.py 文件,如下内容:
from django.conf.urls import url,include
from django.contrib import admin
urlpatterns=[
url(r'^admin/',admin.site.urls),
url(r"^",include("book.urls")) ]
创建 templates 目录,并创建 templates/mybook/index.html 文件 此时需要在settings.py文件下修改配置路径
TEMPLATES = [
{
'BACKEND': 'django.template.backends.django.DjangoTemplates',
'DIRS': [os.path.join(BASE_DIR,"templates")],
'APP_DIRS': True,
'OPTIONS': {
'context_processors': [
'django.template.context_processors.debug',
'django.template.context_processors.request',
'django.contrib.auth.context_processors.auth',
'django.contrib.messages.context_processors.messages',
],
},
},
]
在 webtest/book/views.py 文件下编写视图函数代码
from django.shortcuts import render
from .models import BookInfo
def index(request):
books = BookInfo.objects.all()
return render(request,"book/index.html",{"books":books})
编写视图函数完成后,配置主路由和子路由url 子路由: book/urls.py 文件进行 url 配置(自己创建)
from django.conf.urls import url
from .views import *
urlpatterns=[
url(r"^index/",index),
]
主路由配置:在webtest/webtest/urls.py文件下
from django.contrib import admin
from django.conf.urls import url,include
urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^book/', include("book.urls")),
]
最后,来把上述数据库中的关于图书的信息显示在网页中
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<h1>hello world</h1>
<ul>
{%for book in books%}
<li>{{book.bname}}</li>
{% endfor %}
</ul>
</body>
</ht
完成以上步骤后在在页面上输入相应url即可展示数据. 抽象函数: 对于表格的创建和每一次修改都应该有时间记录,因此可以使用抽象函数创建一个新的数据表来记录这些时间,创建一个新的目录db下创建一个新py文件 注意:不能直接运行直接使用
from django.db import models
class BaseModel(models.Model):
id_delete=models.BooleanField(verbose_name="是否可用",default=False)
create_time = models.DateTimeField(verbose_name="添加时间",auto_now=True)
update_time = models.DateTimeField(verbose_name="修改时间",auto_now_add=True)
class Meta:
abstract=True
添加一个视图函数和抽象函数搭配使用
def add(request):
b1=BookInfo()
b1.bname="简爱"
b1.bpub_date='2001-1-1'
b1.bkind="小说类"
b1.save()
return HttpResponse("hello add")
创建抽象函数后,可在models文件中导入使用,数据类直接继承抽象函数
class BookInfo(BaseModel):
过滤器: 可根据条件过滤掉不需要显示的内容
books = BookInfo.objects.filter(is_delect=0)
|