Python之Django框架
1、Django简介
Python下有多款不同的 Web 框架,Django是最有代表性的一种。许多成功的网站和APP都基于Django。
Django是一个开源的Web应用框架,由Python写成。
Django采用了MVC的软件设计模式,即模型M,视图V和控制器C。
2、Django的特点
1) 强大的数据库功能:用python的类继承,几行代码就可以拥有一个动态的数据库操作API,如果需要也能执行SQL语句。
2) 自带的强大的后台功能:几行代码就让网站拥有一个强大的后台,轻松管理内容。
3) 优雅的网址:用正则匹配网址,传递到对应函数。
4) 模板系统:强大,易扩展的模板系统,设计简易,代码和样式分开设计,更易管理。
5) 缓存系统:与memcached或其它缓存系统联用,表现更出色,加载速度更快。
6) 国际化:完全支持多语言应用,允许你定义翻译的字符,轻松翻译成不同国家的语言。
3、Django项目目录
1) urls.py:网址入口,关联到对应的views.py中的一个函数(或generic类),访问网址就对应一个函数。
2) views.py:处理用户发出的请求,与urls.py对应, 通过渲染templates中的网页可以将显示内容,如登陆后的用户名,用户请求的数据等输出到网页。
3) models.py:与数据库操作相关,存入或读取数据时用到,用不到数据库时可以不使用。
4) forms.py:表单,用户在浏览器上输入数据提交,对数据的验证工作以及输入框的生成等工作,也可以不使用。
5) templates文件夹:views.py中的函数渲染templates中的html模板,得到动态内容的网页,可以用缓存来提高速度。
6) admin.py:后台,可以用很少的代码就拥有一个强大的后台。
7) settings.py:Django 的配置文件,如 DEBUG 的开关,静态文件的位置等。
4、Django基本命令
1) 新建一个项目:
- django-admin.py startproject project-name
在 windows 上如果报错,尝试用 django-admin 代替 django-admin.py 。
2) 新建一个APP:
- python manage.py startapp app-name
或
- django-admin.py startapp app-name
一般一个项目有多个app, 当然通用的app也可以在多个项目中使用。
3) 启动服务器:
- python manage.py runserver 0.0.0.0:8000
或
- python manage.py runserver
前者让其它电脑可连接到服务器,监听机器上所有ip的8000端口,访问时用电脑的ip代替 127.0.0.1(8000为端口号,如果不说明,则端口号默认为8000);后者在本电脑访问服务器,访问时ip为127.0.0.1。
5、视图与网址
views.py:
- from django.http import HttpResponse
- def helloWorld(request):
- return HttpResponse("Hello world! ")
urls.py:
- from django.conf.urls import url
- from . import view
- urlpatterns = [
- url(r'^$', view.helloWorld)
- ]
启动服务器,并在浏览器访问:127.0.0.1:8000。
修改后的urls.py:
- from django.conf.urls import url
- from . import view
- urlpatterns = [
- url(r'^helloWorld$', view.helloWorld)
- ]
启动服务器,并在浏览器访问:127.0.0.1:8000/helloWorld。
url() 函数:可以接收四个参数,分别是两个必选参数regex、view 和两个可选参数kwargs、name:
① regex:正则表达式,与之匹配的 URL 会执行对应的第二个参数 view。
② view:用于执行与正则表达式匹配的 URL 请求。
③ kwargs:视图使用的字典类型的参数。
④ name:用来反向获取 URL。
6、Django模板
1) 实例:
① 在app目录中,创建 templates 目录并建立 helloWorld.html文件:
- <h1>{{ helloWorld }}</h1>
② 向Django说明模板文件的路径,修改settings.py文件,修改 TEMPLATES 中的 DIRS 为 [BASE_DIR+"/templates",]。
③ 修改views.py:
- from django.shortcuts import render
- def hello(request):
- context = {}
- context['helloWorld'] = 'Hello World!'
- return render(request, 'helloWorld.html', context)
render使用了一个字典 context 作为参数,context 字典中元素的键值 "helloWorld" 对应了模板中的变量 "{{ helloWorld }}"。
④ 启动服务器,并在浏览器访问:127.0.0.1:8000/helloWorld。
2) Django 模板标签
① if/else 标签
if/else支持嵌套,{% if %} 标签接受and、or 或not关键字来对多个变量做判断,或对变量取反。
- {% if condition %}
- ...
- {% endif %}
或者:
- {% if condition1 %}
- ...
- {% elif condiiton2 %}
- ...
- {% else %}
- ...
- {% endif %}
② for 标签
{% for %} 允许在一个序列上迭代。支持嵌套。每一次循环中,模板系统会渲染在 {% for %} 和 {% endfor %} 之间的所有内容。
- <ul>
- {% for person in list %}
- <li>{{ person.name }}</li>
- {% endfor %}
- </ul>
给标签增加一个 reversed 使得该列表被反向迭代:
- {% for person in list %}
- ...
- {% endfor %}
③ ifequal/ifnotequal 标签
{% ifequal %} 标签比较两个值,当他们相等时,显示在 {% ifequal %} 和 {% endifequal %} 之中所有的值。和 {% if %} 类似, {% ifequal %} 支持可选的 {% else%} 标签。
- {% ifequal person1 person2 %}
- <h1>YES</h1>
- {% endifequal %}
④ 注释标签
Django 注释使用 {# #}。
⑤ 过滤器
模板过滤器可以在变量被显示前修改它,过滤器使用管道字符:
{{ name|lower }}大写转换为小写。
一个过滤器管道的输出又可以作为下一个管道的输入:
{{ name|first|upper }}将第一个元素转化为大写。
有些过滤器有参数,过滤器的参数跟随冒号之后并总是以双引号包含:
{{ name|truncatewords:"3" }}显示变量的前3个词。
addslashes:添加反斜杠到任何反斜杠、单引号或者双引号前面。
date:按指定的格式字符串参数格式化date或datetime对象,如{{ pub_date|date:"F j, Y" }}。
length:返回变量的长度。
⑥ include 标签
{% include %} 标签允许在模板中包含其它的模板的内容。
- {% include "test.html" %}
7、Django模型
Django 对各种数据库提供了很好的支持,Django 为数据库提供了统一的调用API,可以根据业务需求选择不同的数据库。
以MYSQL数据库为例,安装 mysql 驱动的命令:sudo pip install mysqlclient。
1) 数据库配置
在项目的settings.py文件中找到 DATABASES 配置项,将其信息修改为:
- DATABASES = {
- 'default': {
- 'ENGINE': 'django.db.backends.mysql', # 或者使用 mysql.connector.django
- 'NAME': 'test',
- 'USER': 'test',
- 'PASSWORD': 'test123',
- 'HOST':'localhost',
- 'PORT':'3306',
- }
- }
这里添加了中文注释,所以需要在settings.py 文件头部添加 # -*- coding: UTF-8 -*-。
2) 定义模型
① 创建APP:
Django规定,如果要使用模型,必须要创建一个app,使用以下命令创建一个app:python manage.py startapp TestModel。
② 修改 TestModel/models.py 文件:
- from django.db import models
- class Test(models.Model):
- name = models.CharField(max_length=20)
类名代表了数据库表名,且继承了models.Model,类里面的字段代表数据表中的字段(name),数据类型则由CharField(相当于varchar)、DateField(相当于datetime), max_length 参数限定长度。
③ 在settings.py中找到INSTALLED_APPS这一项,添加:'TestModel'。
④ 在命令行中运行以下命令,创建数据表,表名为应用名_类名(如:TestModel_test):
- python manage.py migrate # 创建表结构
- python manage.py makemigrations TestModel # 让Django知道模型有一些变更
- python manage.py migrate TestModel # 创建表结构
3) 数据库操作
添加database.py文件:
- from django.http import HttpResponse
- from TestModel.models import Test
- def database(request):
- test = Test(name='Alice')
- test.save()
- return HttpResponse("<p>数据添加成功!</p>")
修改 urls.py:
- from django.conf.urls import *
- from . import view,database
- urlpatterns = [
- url(r'^hello$', view.hello),
- url(r'^database$', database.database)
- ]
启动服务器,并在浏览器访问:127.0.0.1:8000/database。
① 添加数据
- from django.http import HttpResponse
- from TestModel.models import Test
- def database(request):
- test = Test(name='Alice')
- test.save()
- return HttpResponse("<p>数据添加成功!</p>")
② 获取数据
- from django.http import HttpResponse
- from TestModel.models import Test
- def database(request):
- # 初始化
- response = ""
- response1 = ""
- # 通过objects这个模型管理器的all()获得所有数据行,相当于SQL中的SELECT * FROM
- list = Test.objects.all()
- # filter相当于SQL中的WHERE,可设置条件过滤结果
- response2 = Test.objects.filter(id=1)
- # 获取单个对象
- response3 = Test.objects.get(id=1)
- # 限制返回的数据,相当于SQL中的OFFSET 0 LIMIT 2;
- Test.objects.order_by('name')[0:2]
- # 数据排序
- Test.objects.order_by("id")
- # 上面的方法可以连锁使用
- Test.objects.filter(name="Alice").order_by("id")
- # 输出所有数据
- for var in list:
- response1 += var.name + " "
- response = response1
- return HttpResponse("<p>" + response + "</p>")
③ 更新数据
- from django.http import HttpResponse
- from TestModel.models import Test
- def database(request):
- # 修改id=1的name字段再save,相当于SQL中的UPDATE
- test = Test.objects.get(id=1)
- test.name='Alice'
- test.save()
- # 另一种方式
- # Test.objects.filter(id=1).update(name='Alice)
- # 修改所有的列
- # Test.objects.all()..update(name='Google')
- return HttpResponse("<p>数据修改成功</p>")
④ 删除数据
删除数据库中的对象只需调用该对象的delete()方法即可:
- from django.http import HttpResponse
- from TestModel.models import Test
- def database(request):
- # 删除id=1的数据
- test = Test.objects.get(id=1)
- test.delete()
- # 另外一种方式
- # Test.objects.filter(id=1).delete()
- # 删除所有数据
- # Test.objects.all().delete()
- return HttpResponse("<p>数据删除成功</p>")
8、Django表单
1) Get方法
① 创建一个 search.py 文件,用于接收用户的请求:
- from django.http import HttpResponse
- from django.shortcuts import render_to_response
- # 表单
- def search_form(request):
- return render_to_response('search_form.html')
- # 接收请求数据
- def search(request):
- request.encoding='utf-8'
- if 'q' in request.GET:
- message = '搜索的内容为: ' + request.GET['q'].encode('utf-8')
- else:
- message = '提交了空表单'
- return HttpResponse(message)
② 在templates中添加 search_form.html 表单:
- <!DOCTYPE html>
- <html>
- <head>
- <meta charset="utf-8">
- <title></title>
- </head>
- <body>
- <form action="/search" method="get">
- <input type="text" name="q">
- <input type="submit" value="搜索">
- </form>
- </body>
- </html>
③ 修改urls.py:
- from django.conf.urls import url
- from . import view,database,search
- urlpatterns = [
- url(r'^helloWorld$', view.helloWorld),
- url(r'^database$', database.database),
- url(r'^search-form$', search.search_form),
- url(r'^search$', search.search)
- ]
④ 启动服务器,并在浏览器访问:127.0.0.1:8000/search_form。
2) Post方法
① 在templates中添加 post.html 表单:
- <!DOCTYPE html>
- <html>
- <head>
- <meta charset="utf-8">
- <title></title>
- </head>
- <body>
- <form action="/search-post" method="post">
- {% csrf_token %}
- <input type="text" name="q">
- <input type="submit" value="搜索">
- </form>
- <p>{{ rlt }}</p>
- </body>
- </html>
{% csrf_token %}标签:csrf 全称是 Cross Site Request Forgery,这是Django提供的防止伪装提交请求的功能。POST 方法提交的表格,必须有此标签。
② 新建 search2.py 文件并使用 search_post 函数来处理 POST 请求:
- from django.shortcuts import render
- from django.views.decorators import csrf
- # 接收POST请求数据
- def search_post(request):
- ctx ={}
- if request.POST:
- ctx['rlt'] = request.POST['q']
- return render(request, "post.html", ctx)
③ 修改urls.py:
- from django.conf.urls import url
- from . import view,database,search
- urlpatterns = [
- url(r'^helloWorld$', view.helloWorld),
- url(r'^database$', database.database),
- url(r'^search-form$', search.search_form),
- url(r'^search$', search.search)
- url(r'^search-post$', search2.search_post)
- ]
④ 启动服务器,并在浏览器访问:127.0.0.1:8000/search_post。
Python之Django框架的更多相关文章
- Python的Django框架中forms表单类的使用方法详解
用户表单是Web端的一项基本功能,大而全的Django框架中自然带有现成的基础form对象,本文就Python的Django框架中forms表单类的使用方法详解. Form表单的功能 自动生成HTML ...
- Python的Django框架中的Cookie相关处理
Python的Django框架中的Cookie相关处理 浏览器的开发人员在非常早的时候就已经意识到. HTTP's 的无状态会对Web开发人员带来非常大的问题,于是(cookies)应运而生. coo ...
- Python的Django框架中的Context使用
Python的Django框架中的Context使用 近期整理些Python方面的知识,一旦你创建一个 Template 对象,你能够用 context 来传递数据给它. 一个context是一系列变 ...
- 如何使用Python的Django框架创建自己的网站
如何使用Python的Django框架创建自己的网站 Django建站主要分四步:1.创建Django项目,2.将网页模板移植到Django项目中,3.数据交互,4.数据库 1创建Django项目 本 ...
- 将Python的Django框架与认证系统整合的方法
将Python的Django框架与认证系统整合的方法 这篇文章主要介绍了将Python的Django框架与认证系统整合的方法,包括指定认证后台和编写认证后台等内容,需要的朋友可以参考下 将Django ...
- Python的Django框架中的URL配置与松耦合
Python的Django框架中的URL配置与松耦合 用 python 处理一个文本时,想要删除其中中某一行,常规的思路是先把文件读入内存,在内存中修改后再写入源文件. 但如果要处理一个很大的文本,比 ...
- Django框架学习——python模拟Django框架(转载)
原贴来源 http://wiki.woodpecker.org.cn/moin/ObpLovelyPython/AbtWebModules python实现web服务器 web开发首先要有web服务器 ...
- python 之 Django框架(Django框架简介、视图装饰器、request对象、Response对象)
12.33 Django框架简介: MVC,全名是Model View Controller,是软件工程中的一种软件架构模式,把软件系统分为三个基本部分:模型(Model).视图(View)和控制器( ...
- python 之 Django框架(服务器程序和应用程序、基础必备三件套及相关配置)
第十二章 Django框架 12.1 服务器程序和应用程序 服务器程序负责对socket服务器进行封装,并在请求到来时,对请求的各种数据进行整理.应用程序则负责具体的逻辑处理.为了方便应用程序的开发, ...
- python使用Django框架开发简单项目
一. (1)使用idea生成一个python项目,安装Django框架: pip install django==1.8.2 (2)初始化项目: django-admin startproject x ...
随机推荐
- 1503: [NOI2004]郁闷的出纳员
Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 13723 Solved: 4989[Submit][Status][Discuss] Descripti ...
- 三十、MySQL 处理重复数据
MySQL 处理重复数据 有些 MySQL 数据表中可能存在重复的记录,有些情况我们允许重复数据的存在,但有时候我们也需要删除这些重复的数据. 本章节我们将为大家介绍如何防止数据表出现重复数据及如何删 ...
- jQuery.each() - jQuery 遍历方法使用介绍
定义和用法 each() 方法规定为每个匹配元素规定运行的函数. 提示:返回 false 可用于及早停止循环. jQuery.each()方法大概有如下几种用法,下面分别进行介绍: 1.选择器.eac ...
- 重置 nexus3 admin 密码
2 简单 3 重构,变化很大 如何处理nexus3忘记admin密码 - CSDN博客 https://blog.csdn.net/tianya6607/article/details/5330562 ...
- JS的四舍五入问题
最近踩了一个坑,mark一下toFixed四舍五入问题,详见代码: var myFixed = function(num, fix) { num = (parseFloat(num) * + ) / ...
- PHP 批量操作 Excel
自己封装了一个批量操作excel文件的方法,通过xls文件地址集合遍历,第三个参数传入一个匿名函数用于每个需求的不同进行的操作,实例中我想要得到列表中含有折字的行,封装成sql语句返回. xls文件超 ...
- 第11课 文章分类(组件化开发) Thinkphp5商城第四季
目录 思路: 控制器里 扩展类里: 视图层: 思路: 控制器查出所有数据后调用扩展类里的无限级分类 public function catetree($cateRes) 方法. 把排序好的数据传给视图 ...
- Linux5个数据段
进程(执行的程序)会占用一定数量的内存,它或是用来存放从磁盘载入的程序代码,或是存放取自用户输入的数据等等.不过进程对这些内存的管理方式因内存用途不一而不尽相同,有些内存是事先静态分配和统一回 ...
- sql优化系列1
sql中索引是否会用到,进而影响查询效率. 带通配符(%)的like语句 1.不能用null作索引,任何包含null值的列都将不会被包含在索引中.即使索引有多列这样的情况下,只要这些列中有一列含有nu ...
- 如何看待微软新开源的LightGBM?
GBDT虽然是个强力的模型,但却有着一个致命的缺陷,不能用类似mini batch的方式来训练,需要对数据进行无数次的遍历.如果想要速度,就需要把数据都预加载在内存中,但这样数据就会受限于内存的大小: ...