搜尋
首頁後端開發Python教學開源Web應用框架Django圖文教程

本文介紹開源Web應用框架Django圖文教學

Python下有許多不同的 Web 框架。 Django是重量級選手中最具代表性的一位。許多成功的網站和APP都基於Django。 Django是一個開放原始碼的Web應用框架,由Python寫成。下面我們就來一步步學習下吧

  本文面向:有python基礎,剛接觸web框架的初學者。

  環境:windows7   python3.5.1  pycharm專業版Django 1.10版pip3

一、Django簡介Web

##   框架,由Python語言編寫......

  重點:一個大而全的框架,啥都替你考慮好了。

1. web框架介紹

  具體介紹Django之前,必須先介紹WEB框架等概念。

  web框架: 別人已經設定好的一個web網站模板,你學習它的規則,然後「填空」或「修改」成你自己需要的樣子。

  一般web框架的架構是這樣的:

開源Web應用框架Django圖文教程

  其它基於python的web框架,如tornado、flask、webpy都是在這個範圍內進行增刪裁剪的。例如tornado用的是自己的非同步非阻塞“wsgi”,flask則只提供了最精簡和基本的框架。 Django則是直接使用了WSGI,並實現了大部分功能。

2. MVC/MTV介紹

  MVC百度百科:全名Model View Controller,是模型(model)-視圖(view)-控制器(controller)的縮寫,一種軟體設計典範,用一種業務邏輯、資料、介面顯示分離的方法組織程式碼,將業務邏輯聚集到一個部件裡面,在改進和個性化定制界面及用戶交互的同時,不需要重新編寫業務邏輯。

  通俗解釋:一種文件的組織和管理形式!不要被縮寫嚇到了,這其實就是把不同類型的檔案放到不同的目錄下的一種方法,然後取了個高大上的名字。當然,它帶來的好處很多,例如前後端分離,鬆散耦合等等,就不詳細說明了。       

  模型(model):定義資料庫相關的內容,一般放在models.py檔案中。

  視圖(view):定義HTML等靜態網頁檔案相關,也就是那些html、css、js等前端的東西。

  控制器(controller):定義業務邏輯相關,就是你的主要程式碼。  

  MTV: 有些WEB框架覺得MVC的字面意思很彆扭,就給它改了一下。 view不再是HTML相關,而是主業務邏輯了,相當於控制器。 html被放在Templates中,稱為模板,於是MVC就變成了MTV。這其實就是一個文字遊戲,和MVC本質上是一樣的,換了個名字和叫法而已,換湯不換藥。

3.Django的MTV模型組織

  目錄分開,就必須有機制將他們在內裡耦合。在Django中,urls、orm、static、settings等扮演重要的角色。一個典型的業務流程是如下圖:

開源Web應用框架Django圖文教程


#那麼我們學Django學的是什麼?

1. 目錄結構規格

2. urls路由方式

#3. settings設定

4.ORM操作

5.範本渲染

6.其它

二、Django專案實例

1.程式安裝

  python3.5、pip3及pycharm專業版自行安裝。

(1)安裝Django:

  這裡只介紹較簡單的pip3指令安裝方式。

  win+r,調出cmd,執行指令:pip3 install django,自動安裝Pypi提供的最新版本。

開源Web應用框架Django圖文教程

安裝完成後如下圖所示:

開源Web應用框架Django圖文教程

#(2)設定係統環境

#成功安裝Django後,在下圖中的路徑可找到django-admin.exe文件,將它加入作業系統環境變數。這樣在以後的呼叫會比較方便。

開源Web應用框架Django圖文教程

開源Web應用框架Django圖文教程

開源Web應用框架Django圖文教程

運行:django-admin help,可以看到下面的內容表示OK。

開源Web應用框架Django圖文教程

2. 建立django專案

  在linux等命令列介面下,使用django提供的指令和vim也能進行專案開發。但是,這裡推薦使用pycharm這個目前最好的python開發IDE

,它功能強大,介面友善。 (下面所有的操作都在pycharm中進行。)

  點選:file-->new project,出現下面的對話方塊。

開源Web應用框架Django圖文教程

選擇Django欄目,輸入專案名稱,這裡採用國際慣例的mysite。選擇python解釋器版本,點選create建立。

Django會自動產生下面的目錄結構:

開源Web應用框架Django圖文教程

#與專案同名的目錄中是設定文件,templates目錄是html檔案存放也就是MTV中的T。 manage.py是django專案管理檔。

開源Web應用框架Django圖文教程

3. 建立APP

  在每個django專案中可以包含多個APP,相當於一個大型專案中的分系統、子模組、功能部件等等,彼此之間比較獨立,但也有連結。

所有的APP共享專案資源。

  在pycharm下方的terminal終端中輸入指令:

  python manage.py startapp cmdb

  這樣就創建了一個叫做cmdb的APP,django自動產生“cmdb”資料夾。

開源Web應用框架Django圖文教程


4. 寫路由

  路由都在urls檔案裡,它將瀏覽器輸入的url對應到對應的業務處理邏輯。

  簡單的urls編寫方法如下圖:

開源Web應用框架Django圖文教程

#5. 撰寫業務處理邏輯

  業務處理邏輯都在views.py文件裡。

開源Web應用框架Django圖文教程

  透過上面兩個步驟,我們將index這個url指向了views裡的index()函數,它接收使用者請求,並傳回一個「hello world」字串。

6. 執行web服務

  現在我們已經可以將web服務運行起來了。

  指令列的方式是:python manage.py runserver 127.0.0.1:8000

  但在pycharm中,你可以這麼做:

 在上部工具列中找到下面圖示的圖示。

開源Web應用框架Django圖文教程

點選下拉箭

開源Web應用框架Django圖文教程

#點擊edit configurations

開源Web應用框架Django圖文教程

開源Web應用框架Django圖文教程# #在host中填入:127.0.0.1   port中填入:8000

OK確定之後,點選綠色的三角,web服務就運作起來了。

開源Web應用框架Django圖文教程

###按圖所示,自動跳到瀏覽器程式介面。顯示的卻是下圖的404頁:#############

修改一下url,加上“/index”,就一切ok了!

開源Web應用框架Django圖文教程

至此,一個最簡單的django所寫的web服務就啟動成功了。

7. 回傳HTML檔案

  上面我們回傳給使用者瀏覽器的是什麼?一個字串!實際上這肯定不行,通常我們都是將html檔案回傳給使用者。

  下面,我們寫這麼一個index.html檔:

開源Web應用框架Django圖文教程

#  再修改一下views檔:

開源Web應用框架Django圖文教程

開源Web應用框架Django圖文教程

開源Web應用框架Django圖文教程

#為了讓django知道我們的html檔案在哪裡,需要修改settings檔案的對應內容。但預設情況下,它正好適用,你無需修改。

開源Web應用框架Django圖文教程接下來,我們可以重新啟動web服務。在瀏覽器刷新一下,你會看到有樣式的「hello world」。

附註:這裡有個小技巧,在多次頻繁重啟服務時,由於連接埠未釋放的原因,容易啟動不了服務,修改一下連接埠就OK了。

8. 使用靜態檔案開源Web應用框架Django圖文教程

  我們已經可以將html檔案回饋給使用者了,但是還不夠,前端三大塊,html、css、js還有各種插件,它們齊全才是一個完整

的頁面。在django中,一般會將靜態檔案放在static目錄中。接下來,在mysite中新建個static目錄。

你的CSS,JS和各種外掛程式都可以放置在這個目錄裡。

為了讓django找到這個目錄,依然需要對settings進行設定:

開源Web應用框架Django圖文教程

同樣,在index.html檔案中,可以引入js檔案了:

開源Web應用框架Django圖文教程

重新啟動web服務,刷新瀏覽器,查看結果。

9. 接收使用者傳送的資料開源Web應用框架Django圖文教程

  上面,我們將一個要素齊全的html檔案回饋給了使用者瀏覽器。但這還不夠,因為web伺服器和用戶之間沒有動態互動。

下面我們設計一個表單,讓使用者輸入使用者名稱和密碼,提交給index這個url,伺服器將會接收到這些資料。

開源Web應用框架Django圖文教程  先修改index.html檔案

#然後修改views.py檔

此時,重啟web服務時,會出錯,因為django有一個跨站請求保護機制,我們在settings檔案中將它關閉。

############再次進入瀏覽器,刷新頁面:###############輸入點東西,然後我們在pycharm中可以看到相應的數據。 ######10. 返回動態頁面######  我們收到了用戶的數據,但返回給用戶的仍然是個靜態頁面,通常我們會根據用戶的數據,進行處理後在返回給用戶。 ######這時候,django採用自己的模板語言,類似jinja2,根據提供的數據,替換掉html中的相應部分,詳細語法入門後再深入學習。 ######先改造views.py檔:###

開源Web應用框架Django圖文教程

再改造index.html檔案:

開源Web應用框架Django圖文教程

#重新啟動服務,重新整理瀏覽器:

開源Web應用框架Django圖文教程

#可以看到,我們獲得了使用者即時輸入的數據,並將它即時展示在了使用者頁面上,這是個不錯的互動過程。

11. 使用資料庫

  流程走到這裡,django的MTV框架基本上已經浮出水面了,只剩下最後的資料庫部分了。

  上面我們雖然和用戶互動得很好,但並沒有保存任何數據,頁面一旦關閉,或伺服器重啟,一切都將回到原始狀態。

  使用資料庫是毫無疑問的,django透過自帶的ORM框架操作資料庫,並且自帶輕量級的sqlite3資料庫。下面我們來看看:

  首先是註冊app:

開源Web應用框架Django圖文教程

#不註冊它,你的資料庫就不知道該給哪個app建立表。

然後我們在settings中,配置資料庫相關的參數,如果使用自帶的sqlite,不需要修改。

開源Web應用框架Django圖文教程

再編輯models.py文件,也就是MTV中的M。

開源Web應用框架Django圖文教程

這裡我們建立了2個字段,分別儲存使用者的名字和密碼。

接下來要在pycharm的teminal中透過指令建立資料庫的表格了。有2個指令,分別是:

python manage.py makemigrations

開源Web應用框架Django圖文教程

再輸入指令:python manage.py migrate

開源Web應用框架Django圖文教程

修改views.py中的業務邏輯

開源Web應用框架Django圖文教程

#重啟web服務後,重新整理瀏覽器頁面,之後與使用者互動的資料都能儲存到資料庫中。任何時候都可以從資料庫讀取數據,展示到頁面上。

至此,一個要素齊全,主體框架展示清晰的django專案完成了,其實很簡單是不是?

三、 Django總結

  作為python必須web框架的Django,它的功能強大,內容全面,但同時也意味著限制頗多,靈活性低,可修改性差,這就是魚和熊掌不可兼得了。我們學習Django,其實就是學習一個軟體,要理解它的基本原理,把握它整體框架,牢記一些基本規則,剩下的就是不斷深入細節,然後熟能生巧、經驗多少的問題了,不存在多高深的不可掌握技術。

  關於學習方法的建議:學習任何東西,不要直接扎入細節,應該先了解它的外圍知識,看看它的整體架構,再學習它的基本內容,然後才是深入學習,打磨技巧!


以上是開源Web應用框架Django圖文教程的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
如何解決Linux終端中查看Python版本時遇到的權限問題?如何解決Linux終端中查看Python版本時遇到的權限問題?Apr 01, 2025 pm 05:09 PM

Linux終端中查看Python版本時遇到權限問題的解決方法當你在Linux終端中嘗試查看Python的版本時,輸入python...

我如何使用美麗的湯來解析HTML?我如何使用美麗的湯來解析HTML?Mar 10, 2025 pm 06:54 PM

本文解釋瞭如何使用美麗的湯庫來解析html。 它詳細介紹了常見方法,例如find(),find_all(),select()和get_text(),以用於數據提取,處理不同的HTML結構和錯誤以及替代方案(SEL)

python對象的序列化和避難所化:第1部分python對象的序列化和避難所化:第1部分Mar 08, 2025 am 09:39 AM

Python 對象的序列化和反序列化是任何非平凡程序的關鍵方面。如果您將某些內容保存到 Python 文件中,如果您讀取配置文件,或者如果您響應 HTTP 請求,您都會進行對象序列化和反序列化。 從某種意義上說,序列化和反序列化是世界上最無聊的事情。誰會在乎所有這些格式和協議?您想持久化或流式傳輸一些 Python 對象,並在以後完整地取回它們。 這是一種在概念層面上看待世界的好方法。但是,在實際層面上,您選擇的序列化方案、格式或協議可能會決定程序運行的速度、安全性、維護狀態的自由度以及與其他系

Python中的數學模塊:統計Python中的數學模塊:統計Mar 09, 2025 am 11:40 AM

Python的statistics模塊提供強大的數據統計分析功能,幫助我們快速理解數據整體特徵,例如生物統計學和商業分析等領域。無需逐個查看數據點,只需查看均值或方差等統計量,即可發現原始數據中可能被忽略的趨勢和特徵,並更輕鬆、有效地比較大型數據集。 本教程將介紹如何計算平均值和衡量數據集的離散程度。除非另有說明,本模塊中的所有函數都支持使用mean()函數計算平均值,而非簡單的求和平均。 也可使用浮點數。 import random import statistics from fracti

如何使用TensorFlow或Pytorch進行深度學習?如何使用TensorFlow或Pytorch進行深度學習?Mar 10, 2025 pm 06:52 PM

本文比較了Tensorflow和Pytorch的深度學習。 它詳細介紹了所涉及的步驟:數據準備,模型構建,培訓,評估和部署。 框架之間的關鍵差異,特別是關於計算刻度的

用美麗的湯在Python中刮擦網頁:搜索和DOM修改用美麗的湯在Python中刮擦網頁:搜索和DOM修改Mar 08, 2025 am 10:36 AM

該教程建立在先前對美麗湯的介紹基礎上,重點是簡單的樹導航之外的DOM操縱。 我們將探索有效的搜索方法和技術,以修改HTML結構。 一種常見的DOM搜索方法是EX

哪些流行的Python庫及其用途?哪些流行的Python庫及其用途?Mar 21, 2025 pm 06:46 PM

本文討論了諸如Numpy,Pandas,Matplotlib,Scikit-Learn,Tensorflow,Tensorflow,Django,Blask和請求等流行的Python庫,並詳細介紹了它們在科學計算,數據分析,可視化,機器學習,網絡開發和H中的用途

如何使用Python創建命令行接口(CLI)?如何使用Python創建命令行接口(CLI)?Mar 10, 2025 pm 06:48 PM

本文指導Python開發人員構建命令行界面(CLIS)。 它使用Typer,Click和ArgParse等庫詳細介紹,強調輸入/輸出處理,並促進用戶友好的設計模式,以提高CLI可用性。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
3 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

VSCode Windows 64位元 下載

VSCode Windows 64位元 下載

微軟推出的免費、功能強大的一款IDE編輯器