在使用Django之前,我們需要把它先安裝好。我們這裡有一個完整的安裝指南,涵蓋了所有的可能性; 本指南將引導您通過簡單的,最小化安裝。
Windows 安裝參考:https://docs.djangoproject.com/en/1.9/howto/windows/
作為一個Python Web框架,Django 需要 Python 環境的支援。Python中包括一個輕量級的資料庫:SQLite,所以我們不會需要建立資料庫。
Python 3.4.x [GCC 4.x] on linux Type "help", "copyright", "credits" or "license" for more information. >>>
如果想使用像PostgreSQL,MySQL和Oracle這些一個「大」資料庫引擎工作。要安裝這樣的資料庫,請查閱資料庫的安裝資訊。
在某些版本的Windows(Windows 7)中,需要確保 Path 系統變數的路徑如下:C:\Python27\;C:\Python27\Lib\site-packages\django\bin\ 在裡面,當然這取決於你的Python版本。
接下來,通過執行以下命令,在windows shell 「cmd」 可能需要管理許可權來安裝Django ?
C:\Python27\Django-1.9.1>python setup.py install
要測試你的安裝,開啟命令提示字元,從 shell 輸入Python可以看到。然後在Python提示符,嘗試匯入Django:
>>> import django >>> print(django.get_version()) 1.9.1
$ python -c "import django; print(django.get_version())"
如果安裝 Django,你應該看到安裝的版本。如果還未安裝會得到一個錯誤提示: 「No module named django」。
本教學是使用 Django1.9和Python2.7或更高版本編寫的。如果Django的版本不匹配,您可以通過使用版本切換 Django 版本,或者 Django 更新到最新版本。如果還在使用Python2.7,則需要稍微調整程式碼,如在註釋中描述。
如果第一次使用Django,必須採取一些初始設定。也就是說,需要自動生成一些程式碼,建立一個Django專案 - 設定Django範例的集合,包括資料庫組態,Django 特定選項和特定應用程式設定。
C:\python27> django-admin startproject mysite
mysite/ manage.py mysite/ __init__.py settings.py urls.py wsgi.py
對上面這些檔案的簡要說明:
C:\python27\mysite> python manage.py runserver
Performing system checks... System check identified no issues (0 silenced). You have unapplied migrations; your app may not work properly until they are applied. Run 'python manage.py migrate' to apply them. January 24, 2016 - 15:50:53 Django version 1.9, using settings 'mysite.settings' Starting development server at http://127.0.0.1:8000/ Quit the server with CONTROL-C.
你已經啟動Django開發伺服器,它是用Python寫的純粹一個輕量級的Web伺服器。我們已經包含在 Django 中了,所以你可以很快開發東西了,而不必處理組態生產伺服器 - 如:Apache 。
需要注意的是:不要在任何類似生產環境中使用此伺服器。它的目的只是用於開發(我們是在使用Web框架,而不是Web伺服器的業務。)
$ python manage.py runserver 8080
$ python manage.py runserver 0.0.0.0:8000
在Django寫的每個應用程式包含一個Python包,遵循一定的約定。 Django提供了一個實用程式,自動生成一個應用程式的基本目錄結構,這樣就可以專注於寫程式碼而不是建立目錄。
C:\python27\mysite> python manage.py startapp polls
polls/ __init__.py admin.py apps.py migrations/ __init__.py models.py tests.py views.py
from django.http import HttpResponse def index(request): return HttpResponse("Hello, world. You're at the polls index.")
polls/ __init__.py admin.py apps.py migrations/ __init__.py models.py tests.py urls.py views.py
from django.conf.urls import url from . import views urlpatterns = [ url(r'^$', views.index, name='index'), ]
下一步驟是讓 polls.urls 模組指向該ROOT_URLCONF。在 mysite/urls.py 中, 增加匯入 django.conf.urls.include 並插入 include() 在URL模式列表中,所以這裡有:
from django.conf.urls import include, url from django.contrib import admin urlpatterns = [ url(r'^polls/', include('polls.urls')), url(r'^admin/', admin.site.urls), ]
C:\Python27\mysite> python manage.py runserver
在瀏覽器中開啟http://localhost:8000/polls/,應該看到如下文字顯示: 「Hello, world. You’re at the polls index.」, 在 index 檢視中所定義。
url()函式傳遞四個引數,兩個必需的:regex 和 view,以及兩個可選:kwargs 和 name。
術語「regex」是一種常用的縮寫形式,意思是「正規表示式」,這是一個語法字串匹配模式,或在我們的範例中是URL模式。Django從第一個正規表示式開始,並使得其遍歷列表,比對每一個正規表示式的請求的URL,直到它找到一個匹配。
請注意,這些正規表示式不搜尋GET和POST引數,或者域名。例如,在一個請求https://www.example.com/myapp/, URLconf 會尋找myapp/.在一個請求 https://www.example.com/myapp/?page=3, URLconf 還將尋找 myapp/.
如果需要使用正規表示式的幫助,請參見維基百科的條目和 re 模組的文件。 然而在實踐中,你並不需要成為正規表示式的專家,因為只需要知道如何捕捉簡單的模式。事實上,複雜的正規表示式可以查詢效能較差,所以你可能不依賴於正規表示式的全部功能。
最後,一個關於效能的事項需要了解:這些正規表示式編譯首次URL組態模組被載入。它們是超級的快(只要查詢東西不是太複雜 - 如上所述)。
當 Django 找到正規表示式匹配,Django呼叫指定的檢視函式,使用 HTTP 請求物件作為第一個引數,從正規表示式「捕獲」的其他引數作為其它的值。 正規表示式使用簡單的捕捉,值傳遞是通過位置引數;如果使用名為捕捉,值傳遞關鍵字引數。我們將給出一個例子。
命名網址可以參考它,明確地從其他地方在Django - 尤其是模板。 這種強大的功能可讓您進行全域性更改到專案的URL模式,而只需要修改一個檔案。接下來我們學習如何在 Django 使用資料功能。
快速入門系列教學:
2 - Django快速入門-資料庫模型
3 - Django快速入門-檢視
4 - Django快速入門-表單