本教程是为Django - 1.11和Python - 3.4或更高版本编写的
实践部分分为:
- 一个让人们查看民意调查并投票的公共网站。
- 一个管理网站,可让您添加,更改和删除民意调查。
我们假设你已经安装了Django。您可以通过在shell提示符下运行以下命令(由$前缀指示)来告诉Django已经安装以及哪个版本:
python -m django --version
如果安装了Django,你应该看到你的安装版本。
如果不是,则会显示“No module named django”错误。
如果您仍在使用Python 2.7,则需要稍微调整代码示例
请参阅如何安装Django以获取有关如何移除较旧版本Django并安装较新版本的建议。
如果这是你第一次使用Django,你需要进行一些初始设置。
也就是说,您需要自动生成一些代码来建立一个Django 项目
从命令行,cd到您要存储代码的目录中,然后运行以下命令:
django-admin startproject mysite
这将mysite在当前目录中创建一个目录。
这个代码应该在哪里居住?
如果你的背景是普通的旧PHP(没有使用现代框架),你可能习惯于把代码放在Web服务器的文档根目录下(比如/var/www)。
用Django,你不这样做。将这些Python代码放在Web服务器的文档根目录中并不是一个好主意,因为这样做有可能使人们能够通过Web查看代码。这对安全性不好。
把你的代码放在文档根目录以外的某个目录中,比如
/home/Django−Temp
我们来看看startproject命令创建的是什么:
dsite /
manager.py
dsite /
__init__.py
setting.py
url.py
wsgi.PY
文件归纳:
最外部 dsite/ 根目录是项目的 容器 。
dsite 的名字与 Django无关; 你可以把它重命名为任何你喜欢的东西。
manage.py:一个命令行实用程序,可让您以各种方式与此Django项目进行交互。
你可以阅读所有的细节 在Django的管理中的manage.py。
内部 dsite/ 目录是 项目 的实际Python包。
它的名字(此处是 dsite)是你在其他应用中需要用来导入的Python包名(例如 dsite.urls)。
dsite/ init.py:一个空的文件,告诉Python 这个目录应该被认为是一个Python包。
dsite/ settings.py: Django项目的配置文件。
Django的设置会告诉你所有的设置工作。
dsite/ urls.py:Django项目的URL声明;
Django 支持站点的“目录”。
dsite/ wsgi.py:WSGI兼容的Web服务器为您的项目提供服务的入口点。
参阅如何使用WSGI进行部署。
让我们验证Django项目能否启用
dsite如果尚未更改到外部目录,请运行以下命令:
python manage.py runserver
执行系统检查...
系统检查确定没有问题(0沉默)。
您有13 个未应用的迁移; 在应用之前,您的应用可能无法正常工作。
运行“python manage.py migrate”来应用它们。
2017年12月10日 - 15:50:53
Django版本1.11,使用设置'dsite.settings'
在http://127.0.0.1:8000/开始运行服务器
使用CONTROL-C退出服务器。
您已经开始使用Django department服务器,这是一个纯粹用Python编写的轻量级Web服务器。
我们在Django中包含了这个功能,所以您可以快速开发,而无需处理配置web服务器(如Apache)
值得注意的是:不要使用类似于生产环境的任何东西。
它仅用于部署时使用。我们正在开发Web框架,而不是Web服务器。
现在服务器正在运行,通过使用Web浏览器访问http://127.0.0.1:8000/。
如果看到一个“欢迎来到Django”的页面,说明简单运行有效!
例如,这个命令在端口8080上启动服务器:
python manage.py runserver 8080
如果要更改服务器的IP,请将其与端口一起传递。
例如,要收听所有可用的公共IP(如果想要在网络上的其他计算机上访问您的web,请使用:
python manage.py runserver 0:8000
0是0.0.0.0的快捷方式。
一个“项目” - 已经建立,可以开始做工作了。
在Django中编写的每个应用程序都包含遵循特定约定的Python包。
Django自带了一个实用程序,可以自动生成应用程序的基本目录结构
因此您可以专注于编写代码而不是创建目录。
应用程序是一个Web应用程序,它执行某些集合操作
例如Weblog系统,公共记录数据库或简单的轮询应用程序
项目是特定网站的配置和应用程序的集合。
项目可以包含多个应用程序。一个应用程序可以在多个项目中。
任何一个应用程序都可以通过添加python路径到在任何项目中
请确保 shell路径 位于与manage.py相同的目录下
键入此命令:
python manage.py startapp Polls
这将创建一个目录polls,其布局如下:
manage.py
polls/
__init__.py
admin.py
apps.py
migrations /
__init__ .py
models.py
tests.py
view.PY
打开文件polls/views.py 并将下面的Python代码放入其中:
在Polls/ views.py 中代码为 :
from django.http import HttpResponse
def index (request ):
return HttpResponse ("Hello,world。You're at the polls index.")
要在polls目录中创建URLconf,请创建一个名为的文件urls.py。
在polls/urls.py文件中包含以下代码:
from django.conf.urls import url
from . import views
urlpatterns = [
URL ([R '^ $' , view.index , name = 'index' ),
]
下一步是将项目 URL中的URL 指向polls.urls模块。
代码如下:
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 ),
]
python同目录包使用包名导入
djngo.conf设置模块
djngo.contrib拓展模块
该include()函数的正则表达式 没有$(字符串结尾匹配字符),而是一个尾部的斜杠。
include()包含其他应用URL格式时,请务必使用。
admin.site.urls 这是唯一不符合你所看到的例外。
如果你看到include(admin.site.urls) 或者不仅仅是 admin.site.urls一项的admin的URL,说明使用的是其他的Django版本。
验证它是否可以工作,运行以下命令:
python manage.py runserver
在你的浏览器中转到http:// localhost:8000 / polls /
可以看到在index视图中定义的内容 。
两个必选:regex(匹配项) 和 view(视图函数)
两个可选:kwargs 和 name。
正则表达式 是一种常用的短格式,用于匹配字符串中的模式的语法,或者在这种情况下匹配的是url模式。
Django 从第一个正则表达式开始,并在URLconf列表中向下,将所请求的URL与每个正则表达式进行比较,直到找到匹配的正则表达式。
请注意,这些正则表达式不搜索GET和POST参数或域名。
例如
在一个请求中
https://www.example.com/myapp/
,URLconf会查找myapp/。
在一个请求中https://www.example.com/myapp/?page=3
,URLconf也将被查找myapp/。
如果您需要正则表达式的帮助,请参阅re模块的文档。
在实践中,你不需要成为正则表达式的专家,因为你只需要知道如何捕捉简单的模式。事实上,复杂的正则表达式可能会有很差的查询性能,所以你可能不应该依赖正则表达式的全部力量。
任意关键字参数都可以在字典中传递给目标视图