day63 Pyhton 框架Django 06
内容回顾
1.装饰器
装饰器:是一个闭包函数,在不改变原函数的代码和调用方式的基础上,给原函数增加功能。
def wrapper(func):
def inner(*args,**kwargs):
# 原函数执行之前
ret = func(*args,**kwargs)
# 原函数执行之后
return ret
return inner
@wrapper # func1 = wrapper(func1)
def func1():
print('func1')
带参数的装饰器:
def outer(flag):
def wrapper(func):
def inner(*args,**kwargs):
# 原函数执行之前
ret = func(*args,**kwargs)
# 原函数执行之后
return ret
return inner
return wrapper
@outer(True) # outer(True) ——》 @wrapper func1 =wrapper(func1)
def func1():
print('func1')
多个装饰器装饰同一个函数
def w1(func):
def inner(*args,**kwargs):
# 原函数执行之前
ret = func(*args,**kwargs)
# 原函数执行之后
return ret
return inner
def w2(func):
def inner(*args,**kwargs):
# 原函数执行之前
ret = func(*args,**kwargs)
# 原函数执行之后
return ret
return inner
@w1 # func1=w1(func1) w1.inner
@w2 # func1 =w2(func1) w2.inner
def func1():
print('func1')
ret = func1() # 原函数的返回值
装饰器的修复技术
from functools import wraps
def wrapper(func):
@wraps(func)
def inner(*args,**kwargs):
# 原函数执行之前
ret = func(*args,**kwargs)
# 原函数执行之后
return ret
return inner
模板中自定义方法
1. 在app下创建一个叫templatetags的python包
2. 在包内创建python文件 *( my_tags.py)
3. 在python文件中写固定的内容:
from django import template
register = template.Library()
1. 写函数 加装饰器
# filter
@register.filter
def x1(value,arg='xxx'):
return True
# simple_tag
@register.simple_tag
def x2(*args,**kwargs):
return True
@register.inclusion_tag('li.html')
def show_li(num):
return {'num':range(num)}
1. inclusion_tag写模板
<ul>
{% for foo in num %}
<li> {{ foo }}</li>
{% endfor %}
</ul>
使用:
在模板中使用:
{% load my_tags %}
{{ 'alex'|x1:'very' }} # True 可以用在if判断中
{% x2 'a' k1='v1' %}
{% show_li 3 %}
<ul>
<li> 0</li>
<li> 1</li>
<li> 2</li>
</ul>
今日内容
视图
1. FBV CBV
FBV : function based view
CBV : class based view
定义:
from django.views import View
class AddPublisher(View):
def get(self,request):
return response
def post(self,request):
return response
使用:
url(r'^add_publisher/', views.AddPublisher.as_view()),
2. CBV的流程:
1. 程序运行的时候AddPublisher.as_view()执行,得到view函数
url(r'^add_publisher/', view),
2. 请求到来的时候,执行view函数:
1. 实例化AddPublisher ——》 self
2. self.request = request
3. 执行 self.dispatch(request, *args, **kwargs)
1. 判断请求方式是否被允许:
1. 如果允许:通过反射获得相应请求方式的方法 ——》handler
2. 如果不允许:self.http_method_not_allowed ——》handler
2. 执行handler ——》 返回响应
3. 加装饰器
1. FBV 直接加装饰器即可
2. CBV
from django.utils.decorators import method_decorator
# 1。加载某一个方法上
@method_decorator(timer)
def get(self, request):
# 2. 加载dispatch方法上面
@method_decorator(timer)
def dispatch(self, request, *args, **kwargs):
# 3. 加在类上
@method_decorator(timer, 'post')
@method_decorator(timer, 'get')
class AddPublisher(View):
4. 是否使用method_decorator的区别
func : <function AddPublisher.get at 0x00000000042CF158>
args: (<app01.views.AddPublisher object at 0x000000000440E898>, <WSGIRequest: GET '/add_publisher/'>)
func : <function method_decorator.<locals>.dec.<locals>.wrapper.<locals>.bound_func at args: 0x00000000045C71E0>
(<WSGIRequest: GET '/add_publisher/'>,)
5. 上传文件
1. form表单指定编码方式enctype="multipart/form-data"
2. 从request.FILES中 文件对象
3. f1.chunks() # 大文件使用
6. requerst对象
print(request.method) # 请求方式 GET POST PUT
print(request.GET) # URL携带的参数 { ‘name’: ['alex'] } [] .get('name')
print(request.POST) # POST请求提交的数据 { ‘name’: ['alex'] } .getlist()
print(request.path_info) # 路径信息 不包含ip和端口 参数
print(request.FILES)
print(request.META)#请求头内容
print(request.COOKIES)
print(request.session)
print(request.get_host())
print(request.get_full_path()) # 路径信息 不包含ip和端口 带参数
print(request.is_ajax()) # 判断是否是ajax请求
7. reponse对象
HttpResponse('字符串 ') ——》 页面展示 字符串
render(request,'html文件名', { k1:v1 }) ——》 返回一个完整HTML页面
redirect(’要跳转的地址‘) ——》重定向 Location : 地址
JsonResponse:
from django.http import JsonResponse
def json_data(request):
data = {'id': 11, 'name': 'alex'}
l1 = ['alex', 'peiqi']
return JsonResponse(l1, safe=False) # Content-Type: application/json
路由
分组
url(r'^blog/([0-9]{4})/([0-9]{2})/$', views.blog),
django会把获取到的参数当做位置参数传递给视图函数
命名分组
url(r'^blog/(?P<year>[0-9]{4})/(?P<month>[0-9]{2})/$', views.blog),
django会把获取到的参数当做关键字参数传递给视图函数
include
from django.conf.urls import url, include
from django.contrib import admin
from app01 import views
urlpatterns = [
url(r'^app01/', include('app01.urls')),
url(r'^app02/', include('app02.urls')),
]
day63 Pyhton 框架Django 06的更多相关文章
- pyhton框架Django之cookie和session
一,cookie和session的理解 cookies 是浏览器为 Web 服务器存储的一小段信息. 每次浏览器从某个服务器请求页面时,它向服务器回送之前收到的cookies.它保存在浏览器下的某个文 ...
- day64 Pyhton 框架Django 07
day67 内容回顾 视图 1. CBV 定义 from django.views import View class Addpub(View): def get(self,request): sel ...
- day62 Pyhton 框架Django 05
内容回顾 1.变量 render(request,'模板文件名',{ k1:v1 }) {{ k1 }} {{ list.0 }} {{ dict.key }} {{ dict.keys }} {{ ...
- day61 Pyhton 框架Django 04
内容回顾 1.django处理请求的流程: 1. 在浏览器的地址栏输入地址,回车发get请求: 2. wsgi模块接收请求: 3. 在urls.py文件中匹配地址,找到对应的函数: 4. 执行函数,返 ...
- day60 Pyhton 框架Django 03
day61 内容回顾 1.安装 1. 命令行: pip install django==1.11.18 pip install django==1.11.18 -i 源 2. pycharm sett ...
- day58 Pyhton 框架Django 01
内容回顾 python基础 网路编程 并发编程 数据库 前端 osi7层 tcp/ip 5层模型 应用层 表示层 ...
- python运维开发(十七)----jQuery续(示例)web框架django
内容目录: jQuery示例 前端插件 web框架 Django框架 jQuery示例 dom事件绑定,dom绑定在form表单提交按钮地方都会绑定一个onclick事件,所有查看网站的人都能看到代码 ...
- Web框架——Django笔记
Web框架--Django笔记 MVC和MTV MVC:Model.View.Controller MTV:Model.Template.View Django--MTV 1.创建Django程序 ...
- Python3.5学习十八 Python之Web框架 Django
Python之Web框架: 本质:Socket 引用wsgiref创建web框架 根据web框架创建过程优化所得: 分目录管理 模板单独目录 执行不同函数单独存入一个方法py文件 Web框架的两种形式 ...
随机推荐
- .NET Core加解密实战系列之——对称加密算法
简介 加解密现状,编写此系列文章的背景: 需要考虑系统环境兼容性问题(Linux.Windows) 语言互通问题(如C#.Java等)(加解密本质上没有语言之分,所以原则上不存在互通性问题) 网上资料 ...
- JavaWeb实现图片上传功能
首先导入文件上传的jar包 然后在Spring-servlet.xml文件中设置上传文件解析器 <!--上传文件解析器--> <bean id="multipartReso ...
- Python数据类型方法整理
前言:主要是对Python数据类型做一个整理,部分知识点源于<python3程序开发指南(第二版)> 一.Python的关键要素 1.1 要素1:数据类型 int类型 str类型 ...
- oracle之DML和DDL语句的其他用法
DML和DDL语句的其他用法 17.1 DML语句-MERGE 作用:把数据从一个表复制到另一个表,插入新数据或替换掉老数据. Oracle 10g中MERGE有如下一些改进: 1.UPDATE或IN ...
- LG P2389 电脑班的裁员
Description ZZY有独特的裁员技巧:每个同学都有一个考试得分$a_i(-1000 \leq a_i \leq 1000)$,在$n$个同学$(n \leq 500)$中选出不大于$k$段$ ...
- 2017年PHP程序员未来路在何方(转)
PHP 从诞生到现在已经有20多年历史,从Web时代兴起到移动互联网退潮,互联网领域各种编程语言和技术层出不穷, Node.js . GO . Python 不断地在挑战 PHP 的地位.这些技术的推 ...
- TDengine常见问题解答(FAQ)
1. TDengine2.0之前的版本升级到2.0及以上的版本应该注意什么?☆☆☆ 2.0版本在之前版本的基础上,进行了完全的重构,配置文件和数据文件是不兼容的.在升级之前务必进行如下操作: 删除配置 ...
- three.js学习4_光源
Three.Light 首先展示的是使用半球光引用的效果, 光源直接放置于场景之上,光照颜色从天空光线颜色颜色渐变到地面光线颜色.光照主要有 AmbientLight 环境光 DirectionalL ...
- Spring--AOP的见解
AOP是指面向切面编程,与JAVA中的动态代理有很深的渊源. 在使用Spring框架时,AOP编程能简化很多繁杂的步骤,精简代码. 切面:横切关注点(跨越程序中多个模块的功能),被模块化的特殊对象,也 ...
- python中生成随机整数(random模块)
1.从一个序列中随机选取一个元素返回: random.choice(sep) 2.用于将一个列表中的元素打乱 random.shuffle(sep) 3.在sep列表中随机选取k个 ...