Django快速上手

来源:互联网 发布:org域名不能认证 编辑:程序博客网 时间:2024/05/16 14:26

最近由于项目需要做一个简易的交互式的界面,所以就学习了一下python的网站开发平台,其中Django由于其更加完备的功能受到了广泛评价,所以就学习了下这个框架。该博客只涉及Django中的普通功能,如果想要写一个小型的网站,那么欢迎参考。通过这个教程,我完成了一个文件管理系统,管理自己的文件,感觉还是很方便的。

  • GetStart
    • 安装
    • 创建工程
    • 创建app
  • 添加url索引
    • 添加url处理
    • url传参数介绍
    • url参数中name参数进阶
  • 模板进阶
    • 可以写一个 basehtml 来包含这些通用文件include
    • 模板中的循环条件判断常用标签过滤器
      • 变量替换
      • for循环
      • 字典调用
      • if和逻辑操作的使用
  • 用户认证

GetStart

安装

pip install django

创建工程

django-admin.py/django-admin startproject Projectname

创建app

django-admin startapp appname
创建app后应当将app的名字加入到settings.py中的installed apps列表中,否则程序无法找到对应的app
中的模板和static目录中的文件。

INSTALLED_APPS = (    'django.contrib.admin',    'django.contrib.auth',    'django.contrib.contenttypes',    'django.contrib.sessions',    'django.contrib.messages',    'django.contrib.staticfiles',    'learn',)

创建结束后,文件系统的结构应如图所示

zqxt_views/├── calc│   ├── __init__.py│   ├── admin.py│   ├── models.py│   ├── tests.py│   └── views.py├── manage.py└── zqxt_views    ├── __init__.py    ├── settings.py    ├── urls.py    └── wsgi.py

其中zqxt_views是项目名称,calc是创建的app名称\

添加url索引

添加url处理

在urls.py文件中,有一个参数urlpatterns,该列表中存放了对应的网站可以处理的url列表。存放格式为\
url(正则,对应的处理方法,名称)

例子:

url(r’^add/$’, calc_views.add, name=’add’)

三个参数可以省略,只有前两个参数是必选参数

url传参数介绍

url(r’^add/(\d+)/(\d+)/$’, calc_views.add2, name=’add2’)

该例子中第一个正则表达式中有两个分组,在调用的时候,这两个分组中的数会被传送到对应的方法中,作为参数使用。

对应的方法的例子。

def add2(request, a, b):    c = int(a) + int(b)    return HttpResponse(str(c))

在这个例子中,存在三个参数,第一个request是网站中必带的参数,后两个为两个分组对应的参数,在调用时,对应的参数会直接赋值给a和b。

url参数中name参数进阶

url(r’^add/$’, calc_views.add, name=’add’), 这里的 name=’add’ 是用来干什么的呢?

简单说,name 可以用于在 templates, models, views ……中得到对应的网址,相当于“给网址取了个名字”,只要这个名字不变,网址变了也能通过名字获取到。

在一般情况下,我们在网址中间有相互跳转操作的时候,需要将对应的网站写在对应的html标签中,例如:

<!DOCTYPE html><html><head>    <title>自强学堂</title></head><body><a href="/add/4/5/">计算 4+5</a></body></html>

但是,当我们需要对网址进行一些修改的时候,就会存在大量的工作量,对每个网站都进行修改,而name的优势就体现在了这里。
我们看下接下来的一个例子。

不带参数的:{% url 'name' %}带参数的:参数可以是变量名{% url 'name' 参数 %}例如:<a href="{% url 'add2' 4 5 %}">link</a>

上诉代码渲染的页面为:

<a href="/add/4/5/">link</a>

因此,只要name不修改,则不需要再修改对应的代码。

当 urls.py 进行更改,前提是不改 name(这个参数设定好后不要轻易改),获取的网址也会动态地跟着变,比如改成:

url(r'^new_add/(\d+)/(\d+)/$', calc_views.add2, name='add2'),

注意看重点 add 变成了 new_add,但是后面的 name=’add2’ 没改,这时 {% url ‘add2’ 4 5 %} 就会渲染对应的网址成 /new_add/4/5/

用在 views.py 或 models.py 等地方的 reverse函数,同样会根据 name 对应的url获取到新的网址。

想要改网址的时候,修改 urls.py 中的正则表达式部分(url 参数第一部分),name 不变的前提下,其它地方都不需要修改。

模板进阶

可以写一个 base.html 来包含这些通用文件(include)

<!DOCTYPE html><html><head>    <title>{% block title %}默认标题{% endblock %} - 自强学堂</title></head><body>{% include 'nav.html' %}{% block content %}<div>这里是默认内容,所有继承自这个模板的,如果不覆盖就显示这里的默认内容。</div>{% endblock %}{% include 'bottom.html' %}{% include 'tongji.html' %}</body></html>

如果需要,写足够多的 block 以便继承的模板可以重写该部分,include 是包含其它文件的内容,就是把一些网页共用的部分拿出来,重复利用,改动的时候也方便一些,还可以把广告代码放在一个单独的html中,改动也方便一些,在用到的地方include进去。其它的页面继承自 base.html 就好了,继承后的模板也可以在 block 块中 include 其它的模板文件。

比如我们的首页 home.html,继承或者说扩展(extends)原来的 base.html,可以简单这样写,重写部分代码(默认值的那一部分不用改)

{% extends 'base.html' %}{% block title %}欢迎光临首页{% endblock %}{% block content %}{% include 'ad.html' %}这里是首页,欢迎光临{% endblock %}

注意:模板一般放在app下的templates中,Django会自动去这个文件夹中找。但 假如我们每个app的templates中都有一个 index.html,当我们在views.py中使用的时候,直接写一个 render(request, ‘index.html’),Django 能不能找到当前 app 的 templates 文件夹中的 index.html 文件夹呢?(答案是不一定能,有可能找错)

Django 模板查找机制: Django 查找模板的过程是在每个 app 的 templates 文件夹中找(而不只是当前 app 中的代码只在当前的 app 的 templates 文件夹中找)。各个 app 的 templates 形成一个文件夹列表,Django 遍历这个列表,一个个文件夹进行查找,当在某一个文件夹找到的时候就停止,所有的都遍历完了还找不到指定的模板的时候就是 Template Not Found (过程类似于Python找包)。这样设计有利当然也有弊,有利是的地方是一个app可以用另一个app的模板文件,弊是有可能会找错了。所以我们使用的时候在 templates 中建立一个 app 同名的文件夹,这样就好了。

这就需要把每个app中的 templates 文件夹中再建一个 app 的名称,仅和该app相关的模板放在 app/templates/app/ 目录下面,

例如:项目 zqxt 有两个 app,分别为 tutorial 和 tryit

zqxt├── tutorial│   ├── __init__.py│   ├── admin.py│   ├── models.py│   ├── templates│   │   └── tutorial│   │       ├── index.html│   │       └── search.html│   ├── tests.py│   └── views.py├── tryit│   ├── __init__.py│   ├── admin.py│   ├── models.py│   ├── templates│   │   └── tryit│   │       ├── index.html│   │       └── poll.html│   ├── tests.py│   └── views.py├── manage.py└── zqxt    ├── __init__.py    ├── settings.py    ├── urls.py    └── wsgi.py

这样,使用的时候,模板就是 “tutorial/index.html” 和 “tryit/index.html” 这样有app作为名称的一部分,就不会混淆。

模板中的循环,条件判断,常用标签,过滤器

变量替换

在模板中使用{{变量名}}的方式
\
在调用模板的时候只需要,如下使用render函数就可以调用对应的模板

# -*- coding: utf-8 -*-from django.shortcuts import renderdef home(request):    string = u"我在自强学堂学习Django,用它来建网站"    return render(request, 'home.html', {'string': string})

for循环

模板代码

{% for i in TutorialList %}{{ i }}{% endfor %}

Python调用代码

def home(request):    TutorialList = ["HTML", "CSS", "jQuery", "Python", "Django"]    return render(request, 'home.html', {'TutorialList': TutorialList})

字典调用

python代码

def home(request):    info_dict = {'site': u'自强学堂', 'content': u'各种IT技术教程'}    return render(request, 'home.html', {'info_dict': info_dict})

模板代码

站点:{{ info_dict.site }} 内容:{{ info_dict.content }}

同时可以使用for循环来遍历字典

{% for key, value in info_dict.items %}    {{ key }}: {{ value }}{% endfor %}

同时for中还有很多的参数

变量                  描述forloop.counter     索引从 1 开始算forloop.counter0    索引从 0 开始算forloop.revcounter  索引从最大长度到 1forloop.revcounter0 索引从最大长度到 0forloop.first       当遍历的元素为第一项时为真forloop.last        当遍历的元素为最后一项时为真forloop.parentloop  用在嵌套的 for 循环中,                    获取上一层 for 循环的 forloop

当列表可能为空的时候,可以使用for empty来进行遍历

<ul>{% for athlete in athlete_list %}    <li>{{ athlete.name }}</li>{% empty %}    <li>抱歉,列表为空</li>{% endfor %}</ul>

if和逻辑操作的使用

==, !=, >=, <=, >, < 这些比较都可以在模板中使用

{% if var >= 90 %}成绩优秀,自强学堂你没少去吧!学得不错{% elif var >= 80 %}成绩良好{% elif var >= 70 %}成绩一般{% elif var >= 60 %}需要努力{% else %}不及格啊,大哥!多去自强学堂学习啊!{% endif %}

and, or, not, in, not in 也可以在模板中使用

{% if num <= 100 and num >= 0 %}num0100之间{% else %}数值不在范围之内!{% endif %}
{% if 'ziqiangxuetang' in List %}自强学堂在名单中{% endif %}

用户认证

{{ request.user }}\
如果登陆就显示内容,不登陆就不显示内容:

{% if request.user.is_authenticated %}    {{ request.user.username }},您好!{% else %}    请登陆,这里放登陆链接{% endif %}

获取当前网址:
{{ request.path }}
\
获取当前 GET 参数:{{ request.GET.urlencode }}
\
合并到一起用的一个例子

<a href="{{ request.path }}?{{ request.GET.urlencode }}&delete=1">当前网址加参数 delete</a>
原创粉丝点击