濮阳杆衣贸易有限公司

主頁 > 知識庫 > python Django框架快速入門教程(后臺管理)

python Django框架快速入門教程(后臺管理)

熱門標(biāo)簽:百應(yīng)電話機器人總部 宿州電話機器人哪家好 西青語音電銷機器人哪家好 地圖標(biāo)注與注銷 南昌地圖標(biāo)注 電梯新時達(dá)系統(tǒng)外呼顯示e 無錫智能外呼系統(tǒng)好用嗎 旅游廁所地圖標(biāo)注怎么弄 成都呼叫中心外呼系統(tǒng)哪家強

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è)計模式,即模型(Model),視圖(View)和模板(Template)。

參考官方文檔:Django官方文檔https://docs.djangoproject.com/zh-hans/3.2/

下面看下python Django框架快速入門,步驟如下所示:

第一步:項目的創(chuàng)建與運行

第一次使用 Django ,那么你必須要照顧一些初始設(shè)置。也就是說,您需要自動生成一些建立 Django
項目的代碼。
從命令行 cd 到您要存儲代碼的目錄,然后運行以下命令:

django-admin startproject BookManage

進(jìn)入項目目錄,目錄結(jié)構(gòu)如下圖:

 目錄說明:
manage.py :一個命令行工具,可以使你用多種方式對 Django 項目進(jìn)行交互
內(nèi)層的目錄:項目的真正的Python包
__init__.py :一個空文件,它告訴Python這個目錄應(yīng)該被看做一個Python包
settings.py :項目的配置
urls.py :項目的URL聲明
wsgi.py :項目與 WSGI 兼容的Web服務(wù)器入口

第二步:應(yīng)用的創(chuàng)建和使用

(1) 創(chuàng)建第一個應(yīng)用程序

Django 自帶一個實用程序,可以自動生成應(yīng)用程序的基本目錄結(jié)構(gòu),因此您可以專注于編寫代碼而不
是創(chuà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 HttpResponse
def index(request):
return HttpResponse("圖書管理系統(tǒng)")

(3) 路由規(guī)則

在 bookApp 目錄中創(chuàng)建一個 URLconf ,創(chuàng)建一個名為 urls.py 。

# bookApp/urls.py
from django.conf.urls import url
from . import views
urlpatterns = [
# 當(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.py
from django.conf.urls import url
from django.contrib import admin
from django.urls import path, include
urlpatterns = [
path('admin/', admin.site.urls),
# 當(dāng)用戶訪問的url地址以book開頭, 請訪問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) 即成功

第三步: 項目的數(shù)據(jù)庫模型

(1). 數(shù)據(jù)庫創(chuàng)建

MariaDB [(none)]> create database BookManage charset=utf8;

(2). 連接 MySQL 數(shù)據(jù)庫配置

在 settings.py 文件中,通過DATABASES項進(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項進(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è)計: 表名: Book
圖書名稱: title
圖書發(fā)布時間: pub_date
英雄表結(jié)構(gòu)設(shè)計: 表名: Hero
英雄姓名: name
英雄性別: gender
英雄簡介: hcontent
所屬圖書: hbook

圖書-英雄的關(guān)系為一對多

# bookApp/models.py
from 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_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
# 自定義對應(yīng)的表名,默認(rèn)表名:bookApp_hero
class Meta:
db_table = "heros"

(3). 生成數(shù)據(jù)庫表

激活模型:編輯 settings.py 文件,將應(yīng)用加入到 INSTALLED_APPS 中

# BookManage/settings.py
# Application definition
INSTALLED_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 -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). 數(shù)據(jù)庫模型基本操作

現(xiàn)在進(jìn)入交互式的Python shell,并使用 Django 提供的免費 API

python manage.py shell

引入需要的包:

from bookApp.models import Hero, Book

查詢所有圖書信息:

Book.objects.all()

新建圖書信息:

from datetime import datetime
book = Book(title="射雕英雄傳", pub_date=datetime(year=1990,month=1,day=10))
book.save()

查找圖書信息:

book = Book.objects.get(pk=1)
book.id
book.title
book.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=book
hero2.Book=book
hero1.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 站點管理、

站點分為“內(nèi)容發(fā)布(后臺管理)”和“公共訪問(前臺管理)”兩部分
“內(nèi)容發(fā)布”的部分負(fù)責(zé)添加、修改、刪除內(nèi)容,開發(fā)這些重復(fù)的功能是一件單調(diào)乏味、缺乏創(chuàng)造力
的工作。
因此, Django 會根據(jù)定義的模型類完全自動地生成管理模塊
Django 框架中有一個非常強大的應(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 makemigrations
python manage.py migrate

(2). 創(chuàng)建管理員用戶

# 按提示輸入用戶名、郵箱、密碼
python manage.py createsuperuser

啟動服務(wù)器,通過 “127.0.0.1:8000/admin” 訪問,輸入上面創(chuàng)建的用戶名、密碼完成登錄
進(jì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 admin
from models import Book
admin.site.register(Book)

刷新管理頁面,可以對 Book 的數(shù)據(jù)進(jìn)行增刪改查操作 ;
問題一: python2 版本中, 如果在 str 方法中返回中文,在修改和添加時會報 ascii 的錯誤
在 str() 方法中,將字符串末尾添加 “.encode('utf-8')” 進(jìn)行字符串編碼
問題二: 后臺管理時, Book管理顯示的是英文, 如何變成中文?

# bookApp/models.py
class Book(models.Model):
# ........此處省略
# 自定義對應(yīng)的表名,默認(rèn)表名:bookApp_book
class Meta:
db_table = "books"
# 單數(shù)時顯示的名稱
verbose_name = '圖書信息'
# 復(fù)數(shù)時顯示的名稱
verbose_name_plural = '圖書信息'

(5). 自定義管理頁面

Django 提供了 admin.ModelAdmin 類
通過定義 ModelAdmin 的子類,來定義模型在 Admin 界面的顯示方式

# 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 = [('基礎(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:顯示字段,可以點擊列頭進(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 = Hero
extra = 2
class BookAdmin(admin.ModelAdmin):
list_display = ['pk', 'title', 'pub_date']
# .......此處省略部分重復(fù)代碼
inlines = [HeroInline]

顯示效果如下:

 布爾值的顯示

發(fā)布性別的顯示不是一個直觀的結(jié)果,可以使用方法進(jìn)行封裝
# bookApp/models.py
class Hero(models.Model):
#
.......此處省略部分重復(fù)代碼
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']

 顯示效果如下:

到此這篇關(guān)于python Django框架快速入門(后臺管理)的文章就介紹到這了,更多相關(guān)python Django入門內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • Python保姆式手把手帶你掌握異常的捕獲和處理
  • python Django的顯示個人信息詳解
  • Python django中如何使用restful框架
  • Python Django搭建文件下載服務(wù)器的實現(xiàn)
  • python中通過Django捕獲所有異常的處理

標(biāo)簽:贛州 渭南 許昌 西安 濰坊 辛集 七臺河 雅安

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《python Django框架快速入門教程(后臺管理)》,本文關(guān)鍵詞  python,Django,框架,快速,入門教程,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《python Django框架快速入門教程(后臺管理)》相關(guān)的同類信息!
  • 本頁收集關(guān)于python Django框架快速入門教程(后臺管理)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    金平| 临邑县| 吉水县| 深圳市| 木里| 辽宁省| 灵寿县| 察哈| 望谟县| 永顺县| 虎林市| 安宁市| 乐昌市| 双鸭山市| 浮山县| 庄浪县| 黄山市| 扎囊县| 广丰县| 杂多县| 安吉县| 平江县| 金沙县| 米脂县| 灵寿县| 托克逊县| 乳源| 达日县| 比如县| 曲阳县| 崇文区| 察哈| 常宁市| 锦屏县| 中山市| 伊川县| 潼关县| 梨树县| 上蔡县| 大庆市| 开封市|