簡介
- 通過簡單示例,使用django完成基本流程的開發,學習django的主要的知識點,在后續課程中會逐個知識點進行深入講解
- 以“圖書-英雄”管理為示例
主要知識點介紹
- 環境搭建
- 定義模型
- 使用后臺管理
- 編寫視圖
- 定義模板
1.1-創建虛擬環境
- 創建:mkvirtualenv [虛擬環境名稱例:h5]
- 進入:workon [虛擬環境名稱例:h5]
所有的虛擬環境,都位于/home/.virtualenvs目錄下
刪除:rmvirtualenv [虛擬環境名稱]
退出:deactivate
查看當前的所有虛擬環境:workon [兩次tab鍵]
查看虛擬環境中已經安裝的包
pip list
pip freeze
安裝Django
- 建議安裝1.8.2版本,這是一個穩定性高、使用廣、文檔多的版本
pip install django==1.8.2
- 查看版本:進入python shell,運行如下代碼
import django
django.get_version()
- 說明:使用pip install django命令進行安裝時,會自動刪除舊版本,再安裝新版本
創建項目
- 命令django-admin startproject practice1
目錄說明
- manage.py:一個命令行工具,可以使你用多種方式對Django項目進行交互
- 內層的目錄:項目的真正的Python包
- _init _.py:一個空文件,它告訴Python這個目錄應該被看做一個Python包
- settings.py:項目的配置
- urls.py:項目的URL聲明
- wsgi.py:項目與WSGI兼容的Web服務器入口
感悟:虛擬環境和項目目錄沒有必然關系.
進入虛擬環境是為操作目錄提供一個不被污染干擾的環境而已.
疑問,不同的的虛擬環境操作相同的目錄估計會崩潰.
1.2-設計模型
本示例完成“圖書-英雄”信息的維護,需要存儲兩種數據:圖書、英雄
圖書表結構設計:
表名:BookInfo
圖書名稱:btitle
圖書發布時間:bpub_date英雄表結構設計:表名:HeroInfo
英雄姓名:hname
英雄性別:hgender
英雄簡介:hcontent
所屬圖書:hbook圖書-英雄的關系為一對多
數據庫配置
- 在settings.py文件中,通過DATABASES項進行數據庫設置
- django支持的數據庫包括:sqlite、mysql等主流數據庫
- Django默認使用SQLite數據庫
創建應用
- 在一個項目中可以創建一到多個應用,每個應用進行一種業務處理
- 創建應用的命令:
python manage.py startapp booktest
-
應用的目錄結構如下圖
practice1目錄結構.png
定義模型類
- 有一個數據表,就有一個模型類與之對應
- 打開models.py文件,定義模型類
- 引入包from django.db import models
- 模型類繼承自models.Model類
- 說明:不需要定義主鍵列,在生成時會自動添加,并且值為自動增長
- 當輸出對象時,會調用對象的str方法
-
定義模型類
projects/practice1/booktest/models.py
from django.db import models
class BookInfo(models.Model):
btitle = models.CharField(max_length=20)
bpub_date = models.DateTimeField()
def _ _str_ _(self):
return "%d" % self.pkclass
HeroInfo(models.Model):
hname = models.CharField(max_length=20)
hgender = models.BooleanField()
hcontent = models.CharField(max_length=100)
hBook = models.ForeignKey('BookInfo')
def _ _str_ _(self):
return "%d" % self.pk
生成數據表
3.激活模型:編輯settings.py文件,將booktest應用加入到installed_apps中
4.生成遷移文件:根據模型類生成sql語句
python manage.py makemigrations
遷移文件被生成到應用的migrations目錄
-
成功顯示:
遷移文件.png
- 執行遷移:執行sql語句生成數據表
python manage.py migrate
測試數據操作
- 進入python shell,進行簡單的模型API練習
python manage.py shell
- 進入shell后提示如下:
- 引入需要的包:
from booktest.models import BookInfo,HeroInfo
from django.utils import timezone
from datetime import *
- 查詢所有圖書信息:
BookInfo.objects.all()
- 新建圖書信息:
b = BookInfo()b.btitle="射雕英雄傳"
b.bpub_date=datetime(year=1990,month=1,day=10)
b.save()
- 查找圖書信息:
b=BookInfo.objects.get(pk=1)
- 輸出圖書信息:
bb.idb.btitle
- 修改圖書信息:
b.btitle=u"天龍八部"b.save()
- 刪除圖書信息:
b.delete()
關聯對象的操作
- 對于HeroInfo可以按照上面的操作方式進行
- 添加,注意添加關聯對象
h=HeroInfo()h.htitle=u'郭靖'h.hgender=Trueh.hcontent=u'降龍十八掌'h.hBook=bh.save()
- 獲得關聯集合:返回當前book對象的所有hero
b.heroinfo_set.all()
- 有一個HeroInfo存在,必須要有一個BookInfo對象,提供了創建關聯的數據:
h=b.heroinfo_set.create(htitle=u'黃蓉',hgender=False,hcontent=u'打狗棍法')h
沒有解決漢字的問題,自己改了setting文件的zh-hans,model更改方法不用遷移,只需重新進入shell
1.3管理站點
服務器
- 運行如下命令可以開啟服務器
python manage.py runserver ip:port
- 可以不寫ip,默認端口為8000
- 這是一個純python編寫的輕量級web服務器,僅在開發階段使用
- 服務器成功啟動后,提示如下信息
- 默認端口是8000,可以修改端口
python manage.py runserver 8080
- 打開瀏覽器,輸入網址“127.0.0.1:8000”可以打開默認頁面
- 如果修改文件不需要重啟服務器,如果增刪文件需要重啟服務器
- 通過ctrl+c停止服務器
管理操作
- 站點分為“內容發布”和“公共訪問”兩部分
- “內容發布”的部分負責添加、修改、刪除內容,開發這些重復的功能是一件單調乏味、缺乏創造力的工作。為此,Django會根據定義的模型類完全自動地生成管理模塊
使用django的管理
- 創建一個管理員用戶
python manage.py createsuperuser,按提示輸入用戶名、郵箱、密碼
- 啟動服務器,通過“127.0.0.1:8000/admin”訪問,輸入上面創建的用戶名、密碼完成登錄
- 進入管理站點,默認可以對groups、users進行管理
管理界面本地化
編輯settings.py文件,設置編碼、時區
LANGUAGE_CODE = 'zh-Hans'TIME_ZONE = 'Asia/Shanghai'
向admin注冊booktest的模型
- 打開booktest/admin.py文件,注冊模型
from django.contrib import admin
from models import BookInfo
admin.site.register(BookInfo)
- 刷新管理頁面,可以對BookInfo的數據進行增刪改查操作
- 問題:如果在str方法中返回中文,在修改和添加時會報ascii的錯誤
- 解決:在str()方法中,將字符串末尾添加“.encode('utf-8')”
自定義管理頁面
- Django提供了admin.ModelAdmin類
- 通過定義ModelAdmin的子類,來定義模型在Admin界面的顯示方式
class QuestionAdmin(admin.ModelAdmin):
...
admin.site.register(Question, QuestionAdmin)
列表頁屬性
- list_display:顯示字段,可以點擊列頭進行排序
list_display = ['pk', 'btitle', 'bpub_date']
- list_filter:過濾字段,過濾框會出現在右側
list_filter = ['btitle']
- search_fields:搜索字段,搜索框會出現在上側
search_fields = ['btitle']
- list_per_page:分頁,分頁框會出現在下側
list_per_page = 10
添加、修改頁屬性
- fields:屬性的先后順序
fields = ['bpub_date', 'btitle']
- fieldsets:屬性分組
fieldsets = [ ('basic',{'fields': ['btitle']}), ('more', {'fields': ['bpub_date']}),]
關聯對象
- 對于HeroInfo模型類,有兩種注冊方式
- 方式一:與BookInfo模型類相同
- 方式二:關聯注冊
按照BookInfor的注冊方式完成HeroInfo的注冊
接下來實現關聯注冊
from django.contrib import admin
from models import BookInfo,HeroInfoclass
HeroInfoInline(admin.StackedInline):
model = HeroInfo extra = 2class
BookInfoAdmin(admin.ModelAdmin):
inlines = [HeroInfoInline]admin.site.register(BookInfo, BookInfoAdmin)
- 可以將內嵌的方式改為表格
class HeroInfoInline(admin.TabularInline)
視圖
- 在django中,視圖對WEB請求進行回應
- 視圖接收reqeust對象作為第一個參數,包含了請求的信息
- 視圖就是一個Python函數,被定義在views.py中
- 更改booktest/view.py
from django.shortcuts import render
from django.http import *
# Create your views here.
def index(request):
return HttpResponse('Hello World!')
- 定義完成視圖后,需要配置urlconf,否則無法處理請求
URLconf
- 在Django中,定義URLconf包括正則表達式、視圖兩部分
- Django使用正則表達式匹配請求的URL,一旦匹配成功,則調用應用的視圖
- 注意:只匹配路徑部分,即除去域名、參數后的字符串
- 在practice1/urls.py插入booktest,使主urlconf連接到booktest.urls模塊
url(r'^', include('booktest.urls')),
在booktest中的urls.py中添加urlconf
from django.conf.urls import url
from . import views
urlpatterns = [
url(r'^$', views.index),
url(r'^([0-9]+)/$', views.detail),
]
- 成功顯示Hello World!
模板
模板是html頁面,可以根據視圖中傳遞的數據填充值
修改settings.py文件,設置TEMPLATES的DIRS值
'DIRS': [os.path.join(BASE_DIR, 'templates')],
- 在模板中訪問視圖傳遞的數據
{{輸出值,可以是變量,也可以是對象.屬性}}{%執行代碼段%}
- 定義index.html模板
- 使用模板
-
成功訪問
4成功訪問.png
傳遞數據
- index
5.view
升級詳情頁面
瀏覽器訪問practice1/urls轉到booktest/urls然后view方法匹配拿到models數據整合傳到index返回到瀏覽器上