一.下载Django
如果电脑没安装 python,点击这里。然后从这里下载 Django 稳定版本。
或者执行命令下载 Django 最新版本:git clone https://github.com/django/django.git
这里我用的是 Mac 自带的python2.7,下载是最新版本的Django后发现python2.7版本需要升级,但是注意,对 iOS 开发者来说,最好不要升级python2.7到python3,因为Xcode只支持最稳定版的python2.7脚本。所以这里我下载的Django版本是1.6.1。
二.安装Django
cd Django sudo python setup.py. install
Python 默认在/Library/Python/2.7中,那么无论如何你在哪里安装完DJango,都会在/Library/Python/2.7/site-packages中生成一个django的文件夹。如果要删除django,只需要把该目录下的django文件夹删除即可。
三.测试LocalHost是否成功
sudo mkdir ~/Djangodemo
/*创建一个用于测试Localhost的网站样例*/
sudo django-admin.py startproject testLocalHost
cd testLocalHost
python manage.py runserver
浏览器打开http://localhost:8000,成功的话你将会看到Django的简单的成功页面
说明:django-admin.py在我们安装完Django之后除了在site-packages中生成django文件夹之外(里面都是一些DJango命令的一些文件和代码),在/usr/local/bin/中也生成了一个名为django-admin.py的链接,这样无论你在何种路径下都可以直接调用django-admin.py文件了。在Win下我们称这个过程为:加入到环境变量。
四.文件结构
1.创建 mysite 工程
删除原来的 LocalHost 工程,创建 mysite 工程,执行命令:$ mkdir mysite
$ django-admin.py startporject mysite
此时的目录结构如下:
mysite/
mysite/
__init__.py
settings.py
urls.py
manage.py
2.manage.py
作用:
把该工程的包加入了 sys.path ;以后你可以直接在你的代码中引用该工程中其他的包。
加载 DJANGO_SETTINGS_MODULE ,指明该工程的配置文件是 mysite/settings.py。
最主要的是它包裹了 django-admin.py 的一些函数,让你可以通过它来操作整个工程。
3.__init__.py
严格意义上讲__init__.py不属于 DJango 的范畴,而是 Python 语言的一种习惯,经常为空文件。主要是告诉工程这是一个包(Package),防止不经意间因为包名为诸如String之类的字符串而引起的混乱,当然你也可以在里面加一些初始化的函数,但不在我们的讨论之列。
4.settings.py
此前我们提到了manage.py的第二件工作便是指定了它是工程的配置文件,那它配置了些什么呢?代码量在其他几个文件中属于比较多的,有一百行的样子,主要设置了关于数据库,后台管理等配置,等到我们要用的时候再详细说明。
5.urls.py
它负责把客户的请求翻译成函数调用。是重要要掌握的文件。
DJango 通过 settings.py 中指定的 URLconf 参数找到对应的 urls.py 文件,此例中正好为我们的这个文件。
DJango 在 urls.py 中找到 urlpatterns 变量。
DJango 收到一个客户地址请求,我们不妨设为 localhost。
DJango 在 urlpatterns 中顺序遍历正则式,找到第一个匹配,调用该正则式对应的函数。
该函数返回客户端所请求的内容。
对开发者来说,真正需要关心的是如何完成正则表达式和对应函数的对应。 如下面例子:
123
urlpatterns=patterns("",url(r'^$','hello.views.home'),)
说明:其中url里面左半部分是正则式,右半部分是函数调用。r说明是raw匹配,表明正则表达式要求每个字符都必须被匹配,是一个可选项,如果不能理解可以省略。^表示匹配开始,$表示匹配结束。所以这个正则表达式匹配了空字符,正好符合地址为localhost的客户请求(DJango收到的请求会自动省略域名,即localhost,即真正的请求字符串为空)。右侧表明腰调用名为hello的app的views.py文件的home函数。
6.增加 hello app
刚才我们在url匹配的时候调用了home函数,此时我们就开始创建它:
python manage.py startapp hello
这样我们在manage.py同级目录下生成了hello目录,进入hello目录其他文件都不用管,也不需要理解,直接打开views.py编辑成如下样子:
from django.http import HttpResponse
def home(request):
return HttpResponse("Hello World")
启动服务器。其实hello相当于是一个app应用被添加进了mysite工程,当特定的请求到来时通过url匹配调用相应app下的views.py中的函数来达到不同的显示效果。
五.Django-URL解析和匹配
1.patterns() 函数
patterns 函数的的原型:
patterns(prefix, pattern_description, ...)
其中prefix表示函数调用的前缀,而pattern_description则是一系列的元组。举例说明prefix的作用:
urlpatterns = patterns("hello.views",
url(r'^$', 'home'),
)
上例和上例的执行效果一样,都表明了hello app下的views文件里的home函数。注意:前缀末尾不必包含“.”;另外因为python函数规定参数不能多于 255 个,因此如果你的映射关系很多,可以利用诸如:urlpatterns += patterns(…)这种形式累加。
2.url()函数
url 函数的原型:
1
url(regex,view,kwargs=None,name=None,prefix='')
其中后三项是可选项,在我们的例子中:regex=”r’^$'”;view=”hello.views.home”;name项给该url命名,这在未来通过name反向确定url有很大的作用;kwargs则传递额外的参数;prefix和此前的prefix作用一致,不过只适用这一条url。
3.通过url传递信息
DJango 在通过url传递参数时有两种方式,一种通过位置,一种通过关键词。我们先看第一种,改此前的映射关系如下:
1
url(r'^(\d{4})/(\d{2})$','hello.views.home'),
修改hello/views.py,增加两行代码如下:
def home(request, year='0000', month='00'):
return HttpResponse("Hello World "+year+" "+month)
这样当用户请求locahost:8000/2015/5时候,相当于在调用home(request, ‘2015’, ’5’),注意此时year和month的相对关系,因为参数传递是基于位置信息的,第一个是4个数字是年,第二个2个数字是月。
下面是第二种,即关键词方式,我们修改两个文件如下:
#mysite/urls.py
url(r'^(?P\d{4})/(?P\d{2})$', 'hello.views.home'),
#hello/views.py
#注意year和month的位置
def home(request, month='00', year='0000'):
return HttpResponse("Hello World "+year+" "+month)