七日Python之路--第十二天(Django Web 开发指南)

时间:2022-07-22
本文章向大家介绍七日Python之路--第十二天(Django Web 开发指南),主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

《Django Web 开发指南》。貌似使用Django1.0版本,基本内容差不多,细读无妨。地址:http://www.jb51.net/books/76079.html


(一)第一部分 入门

(1)内置数字工厂函数

int(12.34)会创建一个新的值为12的整数对象,而float(12)则会返回12.0。

(2)其他序列操作符

连接(+),复制(*),以及检查是否是成员(in, not in)

'**'.join('**') 或 '***%s***%d' % (str, int)

(3)生成器表达式

        even_number = (x for x in range(1000) if x % 2 == 0)

(4)元组

tuple = ('', ) #空元组定义

(5)enumerate

能让你同时迭代和计数的函数

 for i, value in enumerate(data):
            print i, value

(6)匿名函数

        sum = lambda x, y: x+y
        sum(a, b)

(7)函数装饰器 !!!

以‘@’开头,对函数进行‘包装’

(8)*args 和 **kwargs

*args :元组或列表形式

**kwargs :字典形式

(9)实例化

其他语言一般使用new来创建实例,Python使用的是‘初始化程序’initializer 而不是‘构造函数’constructor

即'__init__'函数

Python还支持动态的实例属性。可以‘凭空’创造实例的属性

(10)正则 !

(11)关于模块

Python有导入模块和加载模块之分。模块可以被导入多次,但只会被加载一次。

(12)可变性。!!!

可变性是指对象的值能否被改变。Python对象有:类型,标示符,值

拷贝:copy.copy() 深度拷贝:copy.deepcopy()

(13)动态网站基础

通信:http,URL,请求,响应

(14)不要重复自己(DRY)


(二)深入Django

(1)定义模型

模型变量(model field),模型类(model class),模型类元数据(model class metadata)

(2)为什么使用ORM

封装有用的方法,可移植性,安全性,表现力

(3)主键

使用 AutoField(),或者在某个变量上指定 primary_key = True

(4)模型间的关系 !!

ForeignKey,ManyToManyField,OneToOneField

对于反向访问,可以使用 **_set.all() 进行,也可以指定 related_name = **s 来访问。

对于多对多关系中。也可以通过 through = '***' 来指向一个显式的中间模型类。在这个类上可以添加额外的变量。

限制关系 : limit_choices_to = dict()

(5)模型的继承 !!

抽象基础类(abstract base class)和多表继承(multi-table inheritance)

抽象基础类,纯Python继承。添加 class Meta: abstract = True #这样不会创建数据库表,只是用来为其他实体类提供属性而存在的


唉,刚吃完晚饭。外面竟下起了瓢泼大雨。呆在出租房里竟有一丝的凉意。

--2014年08月09日21:01:08


多表继承,和抽象基础类差别不大。只是不再需要 abstract=True 这个 Meta 属性了。

(6)admin !

(7)使用模型

Django项目中 manage.py 脚本包含了操作数据库的功能。syncdb只能保证所有模型类都有对应的数据库表,但不会修改已经存在的数据库表。

(8)查询语法

查询由模式生成的数据库需要两个类 Manager和QuerySet

(9)QuerySet Q 和 ~Q

使用Q关键字参数封装类进一步参数化。允许你使用更复杂的逻辑。

from django.db.models import Q
        Persons.objects.filter(Q(last='Doe') | (Q(last='Smith') & Q(first='John') & ~Q(middle__startswith='W')))

(10)用Extra调整SQL !!!

接受四个关键字 : select , where , tables , params

(11)利用Django没有提供的SQL特性 !!!!!

定义模式(schema) 和 定制 initial SQL 

视图view,触发器trigger,级联cascade

之前看过一些, 后来使用的不多,基本忘记的差不多了。现在需要好好的研究一下了!

(12)中间件 !!!

Django的中间件就是Python的一个类,实现一个特定的接口。

(13)url配置

url配置中,关于参数。可以使用 : (/?P<param>d{2}/) 来指定 views视图中的参数对应关系。

(14)手动抛异常

        try:
            person = Person.objects.get(pk=id)
        except Person.DoesNotExist:
            raise Http404

或者使用 get_object_or_404

(15)利用 *args / **kwargs

#在视图函数中
def myview(*args, **kwargs):
    #这样我们就可以使用,args[0]或kwargs['object_id'] 而不需要再记住 URLconf中的名称了
##当然在 Django1.6中,完全可以不用在URLconf中使用 ?P<param>

(16)Django的模板

模板是一种独立的文本文件,同时还包含了静态的内容和动态标记的逻辑,循环和数据显示等。

模板系统通常用来生成HTML文件,但还可以生成log文件,E-mail正文,CSV文件等任何文本格式。!

在模板中输出context变量时,会隐式的调用unicode方法。如果试图打印没有__unicode__方法的对象,在模板中是不可见的。

(17)模板过滤器

模板过滤器。

(18) mark- Page 121

--2014年08月10日01:31:25

(17)模板过滤器 !

Django提供了很多来封装Web开发中常见的文本处理工作。

(18)标签

{% for %} 中 有 : {{ forloop }} {{ forloop.first }}{{ forloop.last }}{{ forloop.counter }}

(19)表单

Django提供了forms库把框架里的三个主要组件联系在一起:模型定义的数据库字段,模板里显示的HTML表单标签,还有检验用户输入和显示错误信息的能力。

forms.Form 和 forms.ModelForm 之分。

(20)保存 ModelForm

有一个save()方法,可以将信息保存为数据库里的一条记录,然后返回Model对象结果。

save()方法接受一个可选的参数 “ commit ”默认为“ True ”。

new_person = form.save(commit=False)
# new_persion.attr  do somethings
new_person.save()

关系数据库要求目标记录在引用前就存在!!!

当有关联对象时,Django会给表单添加一个额外的方法 save_m2m

(21)区别于Model

ModelForm的Meta嵌套类允许你定义两个可选属性,fields和exclude。(null=True)

(22)Form实例初始化

form = PersonForm(initial={'name': '请输入姓名'})

(23)Form表单验证

唉 !为了这个验证,折腾了大半夜!!!

# 获取文章详细信息,包含一个CommentForm表单
def detail(req, article_id):
    if req.method == 'POST':
        form = CommentForm(req.POST)
        if form.is_valid():
            name = form.cleaned_data['name']
            address = form.cleaned_data['address']
            email = form.cleaned_data['email']
            context = form.cleaned_data['context']
            article = Article.objects.get(pk=article_id)
            comment = Comment(article=article, name=name, address=address, email=email, context=context)
            comment.save()
            return HttpResponseRedirect('dlog/detail.html')
    else:
        form = CommentForm(initial={'name': '请输入姓名'})
    article = get_object_or_404(Article, pk=article_id)
    comments = article.comment_set.order_by('created_time')
    context = {'article': article, 'comments': comments, 'form': form}
    context.update(csrf(req))
    article.comment_count = article.comment_set.all().count()
    article.save()
    return render_to_response('dlog/detail.html', context)

此页面需要展示Form。当为POST时,绑定Form与request.POST。并验证是否有效。

当不为‘POST’时,只需将Form清空即可。然后处理本views要显示的东西。

官方文档例子:

from django.shortcuts import renderfrom django.http import HttpResponseRedirectdef contact(request):
    if request.method == 'POST': # If the form has been submitted...
        # ContactForm was defined in the previous section
        form = ContactForm(request.POST) # A form bound to the POST data
        if form.is_valid(): # All validation rules pass
            # Process the data in form.cleaned_data
            # ...
            return HttpResponseRedirect('/thanks/') # Redirect after POST
    else:
        form = ContactForm() # An unbound form

    return render(request, 'contact.html', {
        'form': form,
    })

(24)Widget

控制如何显示标签元素的对象。


看文档不仔细啊!唉,害我折腾大半天!!

--2014年08月10日04:13:48