(一)关于Django
Django是一个基于MVC构造的框架。但是在Django中,控制器接受用户输入的部分由框架自行处理,所以 Django 里更关注的是模型(Model)、模板(Template)和视图(Views),称为 MTV模式。
Ubuntu下的安装:一般都自带Python的。网上教程比较多了....
1
2
3
4
5
6
7
8
|
dizzy@dizzy-pc:~$ python
Python 2.7.3 (default, Apr 20 2012, 22:44:07)
[GCC 4.6.3] on linux2
Type "help" , "copyright" , "credits" or "license" for more information.
>>> import django
>>> help(django)
VERSION = (1, 6, 4, 'final' , 0)
#可以查看django版本等信息。
|
(二)第一个Django的app
#环境:Python2.7,Django1.6,Ubuntu12.04
Python 及 Django 安装成功之后,就可以创建Django工程了
(1)教你开始写Django1.6的第1个app
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
|
#先创建一个文件夹
dizzy@dizzy-pc:~$ mkdir Python
dizzy@dizzy-pc:~$ cd Python
#然后创建工程
dizzy@dizzy-pc:~ /Python $ django-admin.py startproject mysite
dizzy@dizzy-pc:~ /Python $ cd mysite
#然后这个工程就可以启动服务了
dizzy@dizzy-pc:~ /Python/mysite $ python manage.py runserver
Validating models...
0 errors found
July 23, 2014 - 14:17:29
Django version 1.6.4, using settings 'mysite.settings'
Starting development server at http: //127 .0.0.1:8000/
Quit the server with CONTROL-C.
#这样,打开浏览器访问: 便可看到: It Worked! 关闭服务:ctrl+c
#新创建的项目里面会有:manage.py文件,mysite文件夹
#在mysite文件夹里面会有:__init__.py,settings.py,urls.py,wsgi.py四个文件
#__init__.py是一个空文件,
#setting.py 是项目的配置文件。需要修改两个地方,这里使用默认的SQLite3数据库
LANGUAGE_CODE = 'zh-cn' #原:en-us
TIME_ZONE = 'Asia/Shanghai' #原:UTC
#配置完之后,便可以创建数据表了
dizzy@dizzy-pc:~ /Python/mysite $ python manage.py syncdb
#创建是还要设置一个超级管理员,用于后台登录。
#设置完之后,开启服务,便可进入后台管理界面了:http://127.0.0.1:8000/admin/
|
(2)教你开始写Django1.6的第1个app
1
2
3
4
5
6
7
|
#创建一个用于投票的app。
#进入mysite工程根目录,创建app
dizzy@dizzy-pc:~ /Python/mysite $ python manage.py startapp polls
dizzy@dizzy-pc:~ /Python/mysite $ ls polls
admin.py __init__.py models.py urls.py views.py
#这样。Django已经生成了,app通常所需的模板文件。
|
下面创建两个models。Poll 和 Choice
1
|
dizzy@dizzy-pc:~ /Python/mysite $ vim polls /models .py
|
修改文件如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
from django.db import models
# Create your models here.
from django.db import models
class Poll(models.Model):
question = models.CharField(max_length = 200 )
pub_date = models.DateTimeField( 'date published' )
class Choice(models.Model):
poll = models.ForeignKey(Poll)
choice_text = models.CharField(max_length = 200 )
votes = models.IntegerField(default = 0 )
#基本创建model过程就是这样,细节还要深入研究!
|
然后修改工程的配置文件setting.py,在INSTALLED_APP元组下面添加刚才创建的app:polls
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
|
dizzy@dizzy - pc:~ / Python / mysite$ vim mysite / settings.py
INSTALLED_APPS = (
'django.contrib.admin' ,
'django.contrib.auth' ,
'django.contrib.contenttypes' ,
'django.contrib.sessions' ,
'django.contrib.messages' ,
'django.contrib.staticfiles' ,
'polls' ,
)
#可以使用 python manage.py sql polls 查看app的建表SQL
#使用 python manage.py syncdb 进行创建数据库表
dizzy@dizzy - pc:~ / Python / mysite$ . / manage.py sql polls
BEGIN;
CREATE TABLE "polls_poll" (
"id" integer NOT NULL PRIMARY KEY,
"question" varchar( 200 ) NOT NULL,
"pub_date" datetime NOT NULL
)
;
CREATE TABLE "polls_choice" (
"id" integer NOT NULL PRIMARY KEY,
"poll_id" integer NOT NULL REFERENCES "polls_poll" ( "id" ),
"choice_text" varchar( 200 ) NOT NULL,
"votes" integer NOT NULL
)
;
COMMIT;
#这样就可以通过设置model让Django自动创建数据库表了
要想在后台admin中管理polls。还需要修改app下面的admin.py 文件。
from django.contrib import admin
# Register your models here.
from django.contrib import admin
from polls.models import Choice,Poll
class ChoiceInLine(admin.StackedInline):
model = Choice
extra = 3
class PollAdmin(admin.ModelAdmin):
fieldsets = [
( None , { 'fields' :[ 'question' ]}),
( 'Date information' , { 'fields' :[ 'pub_date' ], 'classes' :[ 'collapse' ]}),
]
inlines = [ChoiceInLine]
admin.site.register(Poll,PollAdmin)
#这部分代码,大体能看懂,具体的规则还要稍后的仔细研究。
##这部分代码,由于拼写失误,导致多处出错。细节决定成败!!
|
这样再重启服务,就能在后台管理polls应用了。
(3)视图和控制器部分
前面已经完成了model(M)的设置。剩下的只有view(V)和urls(C)了。Django的视图部分,由views.py 和 templates完成。
在polls中,我们将创建4个视图:
- “index” 列表页 – 显示最新投票。
- “detail” 投票页 – 显示一个投票的问题, 以及用户可用于投票的表单。
- “results” 结果页 – 显示一个投票的结果。
- 投票处理 – 对用户提交一个投票表单后的处理。
现在修改 views.py 创建用于视图的函数。
1
|
dizzy@dizzy-pc:~ /Python/mysite $ vim polls /views .py
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
from django.shortcuts import render,get_object_or_404
# Create your views here.
from django.http import HttpResponse
from polls.models import Poll
def index(request):
latest_poll_list = Poll.objects. all ().order_by( '-pub_date' )[: 5 ]
context = { 'latest_poll_list' :latest_poll_list}
return render(request, 'polls/index.html' ,context)
def detail(request,poll_id):
poll = get_object_or_404(Poll,pk = poll_id)
return render(request, 'polls/detail.html' ,{ 'poll' :poll})
def results(request,poll_id):
return HttpResponse( "you're looking at the results of poll %s." % poll_id)
def vote(request,poll_id):
return HttpResponse( "you're voting on poll %s." % poll_id)
#涉及Django的自带函数,不做深究。后面再做研究!
|
要想使试图能被访问,还要配置 urls.py 。mysite是整个网站的URLConf,但每个app可以有自己的URLConf,通过include的方式导入到根配置中即可。现在在polls下面新建 urls.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
from django.conf.urls import patterns,url
from polls import views
urlpatterns = patterns('',
#ex:/polls/
url(r '^$' ,views.index,name = 'index' ),
#ex:/polls/5/
url(r '^(?P<poll_id>\d+)/$' ,views.detail,name = 'detail' ),
#ex:/polls/5/results/
url(r '^(?P<poll_id>\d+)/results/$' ,views.results,name = 'results' ),
#ex:/polls/5/vote/
url(r '^(?P<poll_id>\d+)/vote/$' ,views.vote,name = 'vote' ),
)
#url中,三个参数。正则的url,处理的函数,以及名称
#正则表达式!!!!!
|
然后在根 urls.py 文件中,include这个文件即可。
1
|
dizzy@dizzy-pc:~ /Python/mysite $ vim mysite /urls .py
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
from django.conf.urls import patterns, include, url
from django.contrib import admin
admin.autodiscover()
urlpatterns = patterns('',
# Examples:
# url(r'^$', 'mysite.views.home', name='home'),
# url(r'^blog/', include('blog.urls')),
url(r '^polls/' , include( 'polls.urls' ,namespace = "polls" )),
url(r '^admin/' , include(admin.site.urls)),
)
#有Example:两种形式。因为是元组,所以开始有“ ‘', ”。
|
然后开始创建模板文件。在polls下,创建templates文件夹。下面有index.html, detail.html 两个文件。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
<!-- index.html -->
{% if latest_poll_list %}
<ul>
{% for poll in latest_poll_list %}
<li><a href="{% url 'polls:detail' poll_id=poll.id %}">{{ poll.question }}</a></li>
{% endfor %}
</ul>
{% else %}
<p>No polls are available.</p>
{% endif %}
<!--detail.html-->
<h1>{{ poll.question }}</h1>
<ul>
{% for choice in poll.choice_set.all %}
<li>{{ choice.choice_text }}</li>
{% endfor %}
</ul>
<!-- 视图设置完毕,具体语法还要深入研究! -->
<!-- 现在重启服务, 便可看到相应视图 -->
|
(4)投票功能完善
上面只是简单的实现了视图功能,并没有真正的实现投票功能。接下来就是完善功能。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
#修改模板文件
dizzy@dizzy - pc:~ / Python / mysite$ vim polls / templates / polls / detail.html
#需要加入form表单
<h1>{{ poll.question }}< / h1>
{ % if error_message % }<p><strong>{{ error_message }}< / strong>< / p>{ % endif % }
<form action = "{% url 'polls:vote' poll.id %}" method = "post" >
{ % csrf_token % }
{ % for choice in poll.choice_set. all % }
< input type = "radio" name = "choice" id = "choice{{ forloop.counter }}" value = "{{ choice.id }}" / >
<label for = "choice{{ forloop.counter }}" >{{ choice.choice_text }}< / label><br / >
{ % endfor % }
< input type = "submit" value = "Vote" / >
< / form>
|
然后需要修改 views.py 中的 vote 处理函数。进行post数据的接收与处理。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
# 文件 polls/views.py
from django.shortcuts import get_object_or_404, render
from django.http import HttpResponseRedirect, HttpResponse
from django.core.urlresolvers import reverse
from polls.models import Choice, Poll
# ...
def vote(request, poll_id):
p = get_object_or_404(Poll, pk = poll_id)
try :
selected_choice = p.choice_set.get(pk = request.POST[ 'choice' ])
except (KeyError, Choice.DoesNotExist):
# Redisplay the poll voting form.
return render(request, 'polls/detail.html' , {
'poll' : p,
'error_message' : "You didn't select a choice." ,
})
else :
selected_choice.votes + = 1
selected_choice.save()
# Always return an HttpResponseRedirect after successfully dealing
# with POST data. This prevents data from being posted twice if a
# user hits the Back button.
return HttpResponseRedirect(reverse( 'polls:results' , args = (p. id ,)))
|
在投票成功之后,让用户浏览器重定向到结果 results.html 页。
1
2
3
|
def results(request, poll_id):
poll = get_object_or_404(Poll, pk = poll_id)
return render(request, 'polls/results.html' , { 'poll' : poll})
|
然后就需要创建模板 results.html 。
1
2
3
4
5
6
7
8
9
10
11
|
<!-- polls/templates/polls/results.html -->
<h1>{{ poll.question }}</h1>
<ul>
{% for choice in poll.choice_set.all %}
<li>{{ choice.choice_text }} -- {{ choice.votes }} vote{{ choice.votes|pluralize }}</li>
{% endfor %}
</ul>
<a href="{% url 'polls:detail' poll.id %}">Vote again?</a>
|
至此,重启服务就能看到单选按钮,以及submit了。