python Django框架快速入門教程(后臺管理)
Python下有許多款不同的 Web 框架。Django是重量級選手中最有代表性的一位。許多成功的網(wǎng)站和APP都基于Django。
Django 是一個開放源代碼的 Web 應(yīng)用框架,由 Python 寫成。
Django 遵守 BSD 版權(quán),初次發(fā)布于 2005 年 7 月, 并于 2008 年 9 月發(fā)布了第一個正式版本 1.0 。
Django 采用了 MVT 的軟件設(shè)計(jì)模式,即模型(Model),視圖(View)和模板(Template)。
參考官方文檔:Django官方文檔https://docs.djangoproject.com/zh-hans/3.2/
下面看下python Django框架快速入門,步驟如下所示:
第一步:項(xiàng)目的創(chuàng)建與運(yùn)行第一次使用 Django ,那么你必須要照顧一些初始設(shè)置。也就是說,您需要自動生成一些建立 Django項(xiàng)目的代碼。從命令行 cd 到您要存儲代碼的目錄,然后運(yùn)行以下命令:
django-admin startproject BookManage
進(jìn)入項(xiàng)目目錄,目錄結(jié)構(gòu)如下圖:
目錄說明:manage.py :一個命令行工具,可以使你用多種方式對 Django 項(xiàng)目進(jìn)行交互內(nèi)層的目錄:項(xiàng)目的真正的Python包__init__.py :一個空文件,它告訴Python這個目錄應(yīng)該被看做一個Python包settings.py :項(xiàng)目的配置urls.py :項(xiàng)目的URL聲明wsgi.py :項(xiàng)目與 WSGI 兼容的Web服務(wù)器入口
第二步:應(yīng)用的創(chuàng)建和使用(1) 創(chuàng)建第一個應(yīng)用程序
Django 自帶一個實(shí)用程序,可以自動生成應(yīng)用程序的基本目錄結(jié)構(gòu),因此您可以專注于編寫代碼而不是創(chuàng)建目錄。在一個項(xiàng)目中可以創(chuàng)建一到多個應(yīng)用,每個應(yīng)用進(jìn)行一種業(yè)務(wù)處理創(chuàng)建應(yīng)用的命令:
python3 manage.py startapp bookApp
應(yīng)用的目錄結(jié)構(gòu)如下圖 :
(2) 編寫第一個視圖函數(shù)
打開文件 bookApp/views.py 并放入以下Python代碼:
from django.shortcuts import render# Create your views here.from django.http import HttpResponsedef index(request):return HttpResponse('圖書管理系統(tǒng)')
(3) 路由規(guī)則
在 bookApp 目錄中創(chuàng)建一個 URLconf ,創(chuàng)建一個名為 urls.py 。
# bookApp/urls.pyfrom django.conf.urls import urlfrom . import viewsurlpatterns = [# 當(dāng)用戶訪問bookApp應(yīng)用的主頁時, 執(zhí)行視圖函數(shù)index,反向根據(jù)名稱獲取url地址;url(r’^$’, views.index, name=’index’),]
根據(jù)配置文件 BookManage/settings 可知路由查找的主文件是 BookManage/urls.py , 因此在該文件添加一條 url 規(guī)則:
# BookManage/urls.pyfrom django.conf.urls import urlfrom django.contrib import adminfrom django.urls import path, includeurlpatterns = [path(’admin/’, admin.site.urls),# 當(dāng)用戶訪問的url地址以book開頭, 請?jiān)L問bookApp.urls這個url配置文件進(jìn)行匹配并執(zhí)行對應(yīng)的視圖函數(shù).url(r’^book/’, include(’bookApp.urls’)),]
include()函數(shù)允許引用其他 URLconfs 。
(4) 效果展示
啟動服務(wù)器
python3 manage.py runserver
訪問 url 地址: http:// 127.0.0.1:8000/book/ 如果看到主頁內(nèi)容 圖書管理系統(tǒng) 即成功
(1). 數(shù)據(jù)庫創(chuàng)建
MariaDB [(none)]> create database BookManage charset=utf8;
(2). 連接 MySQL 數(shù)據(jù)庫配置
在 settings.py 文件中,通過DATABASES項(xiàng)進(jìn)行數(shù)據(jù)庫設(shè)置Django 支持的數(shù)據(jù)庫包括: sqlite 、 mysql 等主流數(shù)據(jù)庫Django 默認(rèn)使用 **SQLite** 數(shù)據(jù)庫Django數(shù)據(jù)庫設(shè)置參考文檔其中ENGINE設(shè)置為數(shù)據(jù)庫后端使用。內(nèi)置數(shù)據(jù)庫后端有:’django.db.backends.postgresql’’django.db.backends.mysql’’django.db.backends.sqlite3’’django.db.backends.oracle’
在 BookManage/settings.py 文件中,通過DATABASES項(xiàng)進(jìn)行數(shù)據(jù)庫設(shè)置:
# .......# 注釋之前的sqlite數(shù)據(jù)庫;# DATABASES = {#’default’: {#’ENGINE’: ’django.db.backends.sqlite3’,#’NAME’: os.path.join(BASE_DIR, ’db.sqlite3’),#}# }# 添加新的Mysql數(shù)據(jù)庫連接;DATABASES = {’default’: {’ENGINE’: ’django.db.backends.mysql’,’NAME’: ’BookManage’,’USER’: ’root’,’PASSWORD’: ’westos’,’HOST’: ’localhost’,’PORT’: ’3306’,}}# .......注意: Django 使用 MySQL 數(shù)據(jù)庫需要安裝 PyMySQL ,若已經(jīng)安裝請略過。pip install pymysql
打開 BookManage/__init__.py ,寫入以下代碼導(dǎo)入 pymysql :
import pymysql# MySQLdb只支持Python2.*,還不支持3.可以用PyMySQL代替。pymysql.install_as_MySQLdb()
(2). 創(chuàng)建數(shù)據(jù)庫模型
本示例完成“圖書-英雄”信息的維護(hù),需要存儲兩種數(shù)據(jù):圖書、英雄
圖書表結(jié)構(gòu)設(shè)計(jì): 表名: Book圖書名稱: title圖書發(fā)布時間: pub_date英雄表結(jié)構(gòu)設(shè)計(jì): 表名: Hero英雄姓名: name英雄性別: gender英雄簡介: hcontent所屬圖書: hbook
圖書-英雄的關(guān)系為一對多
# bookApp/models.pyfrom django.db import models# Create your models here.class Book(models.Model):# 定義屬性:默認(rèn)主鍵自增id字段可不寫title = models.CharField(max_length=20)pub_date = models.DateTimeField()# 定義默認(rèn)輸出格式def __str__(self):return '%d' % self.title# 自定義對應(yīng)的表名,默認(rèn)表名:bookApp_bookclass 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# 自定義對應(yīng)的表名,默認(rèn)表名:bookApp_heroclass Meta:db_table = 'heros'
(3). 生成數(shù)據(jù)庫表
激活模型:編輯 settings.py 文件,將應(yīng)用加入到 INSTALLED_APPS 中
# BookManage/settings.py# Application definitionINSTALLED_APPS = [# .......此處省略’django.contrib.staticfiles’,# 新添加的app’bookApp’,]
生成遷移文件:根據(jù)模型類生成 sql 語句
python manage.py makemigrations
產(chǎn)生的遷移文件如下:
執(zhí)行遷移:執(zhí)行 sql 語句生成數(shù)據(jù)表
python manage.py migrate
數(shù)據(jù)庫中查看數(shù)據(jù)庫表是否創(chuàng)建成功?
$ mysql -uroot -pwestosMariaDB [(none)]> use BookManageMariaDB [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). 數(shù)據(jù)庫模型基本操作
現(xiàn)在進(jìn)入交互式的Python shell,并使用 Django 提供的免費(fèi) API
python manage.py shell
引入需要的包:
from bookApp.models import Hero, Book
查詢所有圖書信息:
Book.objects.all()
新建圖書信息:
from datetime import datetimebook = Book(title='射雕英雄傳', pub_date=datetime(year=1990,month=1,day=10))book.save()
查找圖書信息:
book = Book.objects.get(pk=1)book.idbook.titlebook.pub_date
修改圖書信息:
book.title = '天龍八部'book.save()
刪除圖書信息:
book.delete()
添加關(guān)聯(lián)對象
# 書籍的創(chuàng)建book = Book(title='倚天屠龍記', pub_date=datetime(year=1990,month=1,day=10))book.save()# 人物的創(chuàng)建info1 = '峨眉第四代掌門人,先為峨眉派掌門滅絕師太的徒兒,頗獲滅絕師太歡心并對她>青睞有加,將峨眉派鎮(zhèn)派之寶“蛾眉九陽功”傳給了她,張無忌的追求者之一。'info2 = '原名敏敏特穆爾,汝陽王(朝廷大將軍察罕特穆爾)的女兒,封號“紹敏郡主”,>趙敏是她的漢名,是從她的封號“紹敏郡主”而來。'hero1 = Hero(name='周芷若', gender=False, info=info1)hero2 = Hero(name='趙敏', gender=False, info=info2)hero1.Book=bookhero2.Book=bookhero1.save()hero2.save()
獲得關(guān)聯(lián)集合:返回當(dāng)前book對象的所有hero
book.hero_set.all()
有一個 Hero 存在,必須要有一個 Book 對象,提供了創(chuàng)建關(guān)聯(lián)的數(shù)據(jù):
book.hero_set.create(name='張無忌',gender=True,content='武當(dāng)派第二代“張五俠”張翠山與天鷹教紫微堂堂主殷素素的兒子')
第四步: 啟用后臺 Admin 站點(diǎn)管理、
站點(diǎn)分為“內(nèi)容發(fā)布(后臺管理)”和“公共訪問(前臺管理)”兩部分“內(nèi)容發(fā)布”的部分負(fù)責(zé)添加、修改、刪除內(nèi)容,開發(fā)這些重復(fù)的功能是一件單調(diào)乏味、缺乏創(chuàng)造力的工作。因此, Django 會根據(jù)定義的模型類完全自動地生成管理模塊Django 框架中有一個非常強(qiáng)大的應(yīng)用功能: 自動管理界面。 常被Web平臺管理者使用,去管理整個Web平臺。默認(rèn)情況下,在 settings.py 配置文件中 INSTALLED_APPS 包含以下應(yīng)用程序,為了后續(xù)的開發(fā),默認(rèn)這些應(yīng)用程序都是包含在里面的。
(1). 數(shù)據(jù)庫遷移
使用這些 Django 自帶的應(yīng)用程序,需要我們在數(shù)據(jù)庫中創(chuàng)建一些數(shù)據(jù)表對應(yīng),然后才能使用它們。
python manage.py makemigrationspython manage.py migrate
(2). 創(chuàng)建管理員用戶
# 按提示輸入用戶名、郵箱、密碼python manage.py createsuperuser
啟動服務(wù)器,通過 “127.0.0.1:8000/admin” 訪問,輸入上面創(chuàng)建的用戶名、密碼完成登錄進(jìn)入管理站點(diǎn),默認(rèn)可以對 groups、users 進(jìn)行管理
(3). 管理界面本地化
編輯 settings.py 文件,設(shè)置編碼、時區(qū)
LANGUAGE_CODE = ’zh-Hans’TIME_ZONE = ’Asia/Shanghai’
(4). 自定義模型加入后臺管理
打開 bookApp/admin.py 文件,注冊模型
from django.contrib import adminfrom models import Bookadmin.site.register(Book)
刷新管理頁面,可以對 Book 的數(shù)據(jù)進(jìn)行增刪改查操作 ;問題一: python2 版本中, 如果在 str 方法中返回中文,在修改和添加時會報 ascii 的錯誤在 str() 方法中,將字符串末尾添加 “.encode(’utf-8’)” 進(jìn)行字符串編碼問題二: 后臺管理時, Book管理顯示的是英文, 如何變成中文?
# bookApp/models.pyclass Book(models.Model):# ........此處省略# 自定義對應(yīng)的表名,默認(rèn)表名:bookApp_bookclass Meta:db_table = 'books'# 單數(shù)時顯示的名稱verbose_name = ’圖書信息’# 復(fù)數(shù)時顯示的名稱verbose_name_plural = ’圖書信息’
(5). 自定義管理頁面
Django 提供了 admin.ModelAdmin 類通過定義 ModelAdmin 的子類,來定義模型在 Admin 界面的顯示方式
# bookApp/admin.pyfrom django.contrib import adminfrom .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 = [(’基礎(chǔ)信息’, {’fields’: [’title’]}),(’詳細(xì)信息’, {’fields’: [’pub_date’]}), ]# 人物自定義管理頁面class HeroAdmin(admin.ModelAdmin):list_display = [’id’, ’name’, ’gender’, ’content’]list_filter = [’name’]search_fields = [’name’]list_per_page = 10# 關(guān)聯(lián)注冊admin.site.register(Book, BookAdmin)admin.site.register(Hero, HeroAdmin)
列表頁屬性性
ist_display:顯示字段,可以點(diǎn)擊列頭進(jìn)行排序list_display = [’pk’, ’title’, ’pub_date’]list_filter:過濾字段,過濾框會出現(xiàn)在右側(cè)list_filter = [’title’]search_fields:搜索字段,搜索框會出現(xiàn)在上側(cè)search_fields = [’title’]list_per_page:分頁,分頁框會出現(xiàn)在下側(cè)list_per_page = 10
添加、修改頁屬性
fields:屬性的先后順序fields = [’pub_date’, ’title’]fieldsets :屬性分組, 注意: fields和fieldsets 只能設(shè)置一個.fieldsets = [(’基礎(chǔ)信息’, {’fields’: [’title’]}),(’詳細(xì)信息’, {’fields’: [’pub_date’]}), ]
關(guān)聯(lián)對象
對于 Hero 模型類,有兩種注冊方式方式一:與 Book 模型類相同方式二:關(guān)聯(lián)注冊admin.StackedInline : 內(nèi)嵌關(guān)聯(lián)注冊類admin.TabularInline : 表格 關(guān)聯(lián)注冊類
# bookApp/admin.py# class HeroInline(admin.TabularInline):class HeroInline(admin.StackedInline):model = Heroextra = 2class BookAdmin(admin.ModelAdmin):list_display = [’pk’, ’title’, ’pub_date’]# .......此處省略部分重復(fù)代碼inlines = [HeroInline]
顯示效果如下:
布爾值的顯示
發(fā)布性別的顯示不是一個直觀的結(jié)果,可以使用方法進(jìn)行封裝# bookApp/models.pyclass Hero(models.Model):#.......此處省略部分重復(fù)代碼def sex(self):if self.gender:return'男'else:return'女'在 admin 注冊中使用 sex 代替 gender# bookApp/admin.pyclass HeroAdmin(admin.ModelAdmin):list_display = [’id’, ’name’, ’sex’, ’content’]
顯示效果如下:
到此這篇關(guān)于python Django框架快速入門(后臺管理)的文章就介紹到這了,更多相關(guān)python Django入門內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
