python下有许多款不同的 web 框架。django是重量级选手中最有代表性的一位。许多成功的网站和app都基于django。
django 是一个开放源代码的 web 应用框架,由 python 写成。
django 遵守 bsd 版权,初次发布于 2005 年 7 月, 并于 2008 年 9 月发布了第一个正式版本 1.0 。
django 采用了 mvt 的软件设计模式,即模型(model),视图(view)和模板(template)。
参考官方文档:django官方文档
下面看下python django框架快速入门,步骤如下所示:
第一步:项目的创建与运行
第一次使用 django ,那么你必须要照顾一些初始设置。也就是说,您需要自动生成一些建立 django
项目的代码。
从命令行 cd 到您要存储代码的目录,然后运行以下命令:
1
|
django - admin startproject bookmanage
|
进入项目目录,目录结构如下图:
目录说明:
manage.py :一个命令行工具,可以使你用多种方式对 django 项目进行交互
内层的目录:项目的真正的python包
__init__.py :一个空文件,它告诉python这个目录应该被看做一个python包
settings.py :项目的配置
urls.py :项目的url声明
wsgi.py :项目与 wsgi 兼容的web服务器入口
第二步:应用的创建和使用
(1) 创建第一个应用程序
django 自带一个实用程序,可以自动生成应用程序的基本目录结构,因此您可以专注于编写代码而不
是创建目录。
在一个项目中可以创建一到多个应用,每个应用进行一种业务处理
创建应用的命令:
1
|
python3 manage.py startapp bookapp
|
应用的目录结构如下图 :
(2) 编写第一个视图函数
打开文件 bookapp/views.py 并放入以下python代码:
1
2
3
4
5
|
from django.shortcuts import render
# create your views here.
from django.http import httpresponse
def index(request):
return httpresponse( "图书管理系统" )
|
(3) 路由规则
在 bookapp 目录中创建一个 urlconf ,创建一个名为 urls.py 。
1
2
3
4
5
6
7
|
# bookapp/urls.py
from django.conf.urls import url
from . import views
urlpatterns = [
# 当用户访问bookapp应用的主页时, 执行视图函数index,反向根据名称获取url地址;
url(r '^$' , views.index, name = 'index' ),
]
|
根据配置文件 bookmanage/settings 可知路由查找的主文件是 bookmanage/urls.py , 因此在该文件
添加一条 url 规则:
1
2
3
4
5
6
7
8
9
10
|
# bookmanage/urls.py
from django.conf.urls import url
from django.contrib import admin
from django.urls import path, include
urlpatterns = [
path( 'admin/' , admin.site.urls),
# 当用户访问的url地址以book开头, 请访问bookapp.urls这个url配置文件进行匹配并执行对应
的视图函数.
url(r '^book/' , include( 'bookapp.urls' )),
]
|
include()函数允许引用其他 urlconfs 。
(4) 效果展示
启动服务器
1
|
python3 manage.py runserver
|
访问 url 地址: http:// 127.0.0.1:8000/book/ 如果看到主页内容 图书管理系统 即成功
第三步: 项目的数据库模型
(1). 数据库创建
1
|
mariadb [(none)]> create database bookmanage charset = utf8;
|
(2). 连接 mysql 数据库配置
在 settings.py 文件中,通过databases项进行数据库设置
django 支持的数据库包括: sqlite 、 mysql 等主流数据库
django 默认使用 **sqlite** 数据库
django数据库设置参考文档
其中engine设置为数据库后端使用。内置数据库后端有:
'django.db.backends.postgresql'
'django.db.backends.mysql'
'django.db.backends.sqlite3'
'django.db.backends.oracle'
在 bookmanage/settings.py 文件中,通过databases项进行数据库设置:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
|
# .......
# 注释之前的sqlite数据库;
# databases = {
#
'default' : {
#
'engine' : 'django.db.backends.sqlite3' ,
#
'name' : os.path.join(base_dir, 'db.sqlite3' ),
#
}
# }
# 添加新的mysql数据库连接;
databases = {
'default' : {
'engine' : 'django.db.backends.mysql' ,
'name' : 'bookmanage' ,
'user' : 'root' ,
'password' : 'westos' ,
'host' : 'localhost' ,
'port' : '3306' ,
}
}
# .......
注意: django 使用 mysql 数据库需要安装 pymysql ,若已经安装请略过。
pip install pymysql
|
打开 bookmanage/__init__.py ,写入以下代码导入 pymysql :
1
2
3
|
import pymysql
# mysqldb只支持python2.*,还不支持3.可以用pymysql代替。
pymysql.install_as_mysqldb()
|
(2). 创建数据库模型
本示例完成“图书-英雄”信息的维护,需要存储两种数据:图书、英雄
图书表结构设计: 表名: book
图书名称: title
图书发布时间: pub_date
英雄表结构设计: 表名: hero
英雄姓名: name
英雄性别: gender
英雄简介: hcontent
所属图书: hbook
图书-英雄的关系为一对多
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
# bookapp/models.py
from django.db import models
# create your models here.class book(models.model):
# 定义属性:默认主键自增id字段可不写
title = models.charfield(max_length = 20 )
pub_date = models.datetimefield()
# 定义默认输出格式
def __str__( self ):
return "%d" % self .title
# 自定义对应的表名,默认表名:bookapp_book
class meta:
db_table = "books"
class hero(models.model):
name = models.charfield(max_length = 20 )
gender = models.booleanfield()
content = models.charfield(max_length = 100 )
book = models.foreignkey( 'book' , on_delete = false)
def __str__( self ):
return "%s" % self .name
# 自定义对应的表名,默认表名:bookapp_hero
class meta:
db_table = "heros"
|
(3). 生成数据库表
激活模型:编辑 settings.py 文件,将应用加入到 installed_apps 中
1
2
3
4
5
6
7
8
|
# bookmanage/settings.py
# application definition
installed_apps = [
# .......此处省略
'django.contrib.staticfiles' ,
# 新添加的app
'bookapp' ,
]
|
生成迁移文件:根据模型类生成 sql 语句
1
|
python manage.py makemigrations
|
产生的迁移文件如下:
执行迁移:执行 sql 语句生成数据表
1
|
python manage.py migrate
|
数据库中查看数据库表是否创建成功?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
|
$ mysql - uroot - pwestos
mariadb [(none)]> use bookmanage
mariadb [bookmanage]> show tables;
mariadb [bookmanage]> desc books;
+ - - - - - - - - - - + - - - - - - - - - - - - - + - - - - - - + - - - - - + - - - - - - - - - + - - - - - - - - - - - - - - - - +
| field
| type
| null | key | default | extra
|
+ - - - - - - - - - - + - - - - - - - - - - - - - + - - - - - - + - - - - - + - - - - - - - - - + - - - - - - - - - - - - - - - - +
| id | int ( 11 )
| title | varchar( 20 ) | no
| pub_date | datetime
| no
| no
| pri | null | auto_increment |
| | null | |
| | null | |
+ - - - - - - - - - - + - - - - - - - - - - - - - + - - - - - - + - - - - - + - - - - - - - - - + - - - - - - - - - - - - - - - - +
mariadb [bookmanage]> desc heros;
+ - - - - - - - - - + - - - - - - - - - - - - - - + - - - - - - + - - - - - + - - - - - - - - - + - - - - - - - - - - - - - - - - +
| field
| type
| null | key | default | extra
|
+ - - - - - - - - - + - - - - - - - - - - - - - - + - - - - - - + - - - - - + - - - - - - - - - + - - - - - - - - - - - - - - - - +
| id | int ( 11 ) | no | pri | null | auto_increment |
| name | varchar( 20 ) | no | | null | |
| gender | tinyint( 1 ) | no | | null | |
| content | varchar( 100 ) | no | | null | |
| book_id | int ( 11 ) | mul | null | |
| no
+ - - - - - - - - - + - - - - - - - - - - - - - - + - - - - - - + - - - - - + - - - - - - - - - + - - - - - - - - - - - - - - - - +
5 rows in set ( 0.00 sec)
|
(4). 数据库模型基本操作
现在进入交互式的python shell,并使用 django 提供的免费 api
1
|
python manage.py shell
|
引入需要的包:
1
|
from bookapp.models import hero, book
|
查询所有图书信息:
1
|
book.objects. all ()
|
新建图书信息:
1
2
3
|
from datetime import datetime
book = book(title = "射雕英雄传" , pub_date = datetime(year = 1990 ,month = 1 ,day = 10 ))
book.save()
|
查找图书信息:
1
2
3
4
|
book = book.objects.get(pk = 1 )
book. id
book.title
book.pub_date
|
修改图书信息:
1
2
|
book.title = "天龙八部"
book.save()
|
删除图书信息:
1
|
book.delete()
|
添加关联对象
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
# 书籍的创建
book = book(title = "倚天屠龙记" , pub_date = datetime(year = 1990 ,month = 1 ,day = 10 ))
book.save()
# 人物的创建
info1 = "峨眉第四代掌门人,先为峨眉派掌门灭绝师太的徒儿,颇获灭绝师太欢心并对她>青睐有加,将峨
眉派镇派之宝“蛾眉九阳功”传给了她,张无忌的追求者之一。"
info2 = "原名敏敏特穆尔,汝阳王(朝廷大将军察罕特穆尔)的女儿,封号“绍敏郡主”,>赵敏是她的汉
名,是从她的封号“绍敏郡主”而来。"
hero1 = hero(name = "周芷若" , gender = false, info = info1)
hero2 = hero(name = "赵敏" , gender = false, info = info2)
hero1.book = book
hero2.book = book
hero1.save()
hero2.save()
|
获得关联集合:返回当前book对象的所有hero
1
|
book.hero_set. all ()
|
有一个 hero 存在,必须要有一个 book 对象,提供了创建关联的数据:
1
2
3
|
book.hero_set.create(name = "张无忌" ,
gender = true,
content = "武当派第二代“张五侠”张翠山与天鹰教紫微堂堂主殷素素的儿子" )
|
第四步: 启用后台 admin 站点管理、
站点分为“内容发布(后台管理)”和“公共访问(前台管理)”两部分
“内容发布”的部分负责添加、修改、删除内容,开发这些重复的功能是一件单调乏味、缺乏创造力
的工作。
因此, django 会根据定义的模型类完全自动地生成管理模块
django 框架中有一个非常强大的应用功能: 自动管理界面。 常被web平台管理者使用,去管理整个
web平台。
默认情况下,在 settings.py 配置文件中 installed_apps 包含以下应用程序,为了后续的开发,默
认这些应用程序都是包含在里面的。
(1). 数据库迁移
使用这些 django 自带的应用程序,需要我们在数据库中创建一些数据表对应,然后才能使用它们。
1
2
|
python manage.py makemigrations
python manage.py migrate
|
(2). 创建管理员用户
1
2
|
# 按提示输入用户名、邮箱、密码
python manage.py createsuperuser
|
启动服务器,通过 “127.0.0.1:8000/admin” 访问,输入上面创建的用户名、密码完成登录
进入管理站点,默认可以对 groups、users 进行管理
(3). 管理界面本地化
编辑 settings.py 文件,设置编码、时区
1
2
|
language_code = 'zh-hans'
time_zone = 'asia/shanghai'
|
(4). 自定义模型加入后台管理
打开 bookapp/admin.py 文件,注册模型
1
2
3
|
from django.contrib import admin
from models import book
admin.site.register(book)
|
刷新管理页面,可以对 book 的数据进行增删改查操作 ;
问题一: python2 版本中, 如果在 str 方法中返回中文,在修改和添加时会报 ascii 的错误
在 str() 方法中,将字符串末尾添加 “.encode('utf-8')” 进行字符串编码
问题二: 后台管理时, book管理显示的是英文, 如何变成中文?
1
2
3
4
5
6
7
8
9
10
|
# bookapp/models.py
class book(models.model):
# ........此处省略
# 自定义对应的表名,默认表名:bookapp_book
class meta:
db_table = "books"
# 单数时显示的名称
verbose_name = '图书信息'
# 复数时显示的名称
verbose_name_plural = '图书信息'
|
(5). 自定义管理页面
django 提供了 admin.modeladmin 类
通过定义 modeladmin 的子类,来定义模型在 admin 界面的显示方式
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
# bookapp/admin.py
from django.contrib import admin
from .models import book, hero
# 书籍自定义管理页面
class bookadmin(admin.modeladmin):
list_display = [ 'pk' , 'title' , 'pub_date' ]
list_filter = [ 'title' ]
search_fields = [ 'title' ]
list_per_page = 10 # fields = ['pub_date', 'title']
fieldsets = [( '基础信息' , { 'fields' : [ 'title' ]}),
( '详细信息' , { 'fields' : [ 'pub_date' ]}), ]
# 人物自定义管理页面
class heroadmin(admin.modeladmin):
list_display = [ 'id' , 'name' , 'gender' , 'content' ]
list_filter = [ 'name' ]
search_fields = [ 'name' ]
list_per_page = 10
# 关联注册
admin.site.register(book, bookadmin)
admin.site.register(hero, heroadmin)
|
列表页属性性
1
2
3
4
5
6
7
8
|
ist_display:显示字段,可以点击列头进行排序
list_display = [ 'pk' , 'title' , 'pub_date' ]
list_filter:过滤字段,过滤框会出现在右侧
list_filter = [ 'title' ]
search_fields:搜索字段,搜索框会出现在上侧
search_fields = [ 'title' ]
list_per_page:分页,分页框会出现在下侧
list_per_page = 10
|
添加、修改页属性
1
2
3
4
5
|
fields:属性的先后顺序
fields = [ 'pub_date' , 'title' ]
fieldsets :属性分组, 注意: fields和fieldsets 只能设置一个.
fieldsets = [( '基础信息' , { 'fields' : [ 'title' ]}),
( '详细信息' , { 'fields' : [ 'pub_date' ]}), ]
|
关联对象
对于 hero 模型类,有两种注册方式
方式一:与 book 模型类相同
方式二:关联注册
admin.stackedinline : 内嵌关联注册类
admin.tabularinline : 表格 关联注册类
1
2
3
4
5
6
7
8
9
|
# bookapp/admin.py
# class heroinline(admin.tabularinline):
class heroinline(admin.stackedinline):
model = hero
extra = 2
class bookadmin(admin.modeladmin):
list_display = [ 'pk' , 'title' , 'pub_date' ]
# .......此处省略部分重复代码
inlines = [heroinline]
|
显示效果如下:
布尔值的显示
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
发布性别的显示不是一个直观的结果,可以使用方法进行封装
# bookapp/models.py
class hero(models.model):
#
.......此处省略部分重复代码
def sex( self ):
if self .gender:
return
"男"
else :
return
"女"
在 admin 注册中使用 sex 代替 gender
# bookapp/admin.py
class heroadmin(admin.modeladmin):
list_display = [ 'id' , 'name' , 'sex' , 'content' ]
|
显示效果如下:
到此这篇关于python django框架快速入门(后台管理)的文章就介绍到这了,更多相关python django入门内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!
原文链接:https://blog.csdn.net/weixin_56993834/article/details/118799553