欢迎来到牧飞之家的Django

Django 是一个现代的,设计者友好的Python 模板语言。 它速度快,被广泛使用,并且提供了可选的沙箱模板执行环境保证安全:

特性:

Django 文档

  • 过滤器
  • models filter筛选条件
  • HttpResponse
  • 过滤器
  • 一、形式:小写
    	{{ name | lower }}
    
    二、过滤器是可以嵌套的,字符串经过三个过滤器,第一个过滤器转换为小写,第二个过滤器输出首字母,第三个过滤器将首字母转换成大写
    	{{ str|lower|first|upper }}
    
    三、过滤器的参数
    	{{ bio | truncatewords:"30" }} 显示前30个字
    
    	{{ pub_date | date:"F j, Y" }} 格式化
    
    	过滤器列表
    
    	{{ 123|add:"5" }} 给value加上一个数值
    
    	{{ "AB'CD"|addslashes }} 单引号加上转义号,一般用于输出到javascript中
    
    	{{ "abcd"|capfirst }} 第一个字母大写
    
    	{{ "abcd"|center:"50" }} 输出指定长度的字符串,并把值对中
    
    	{{ "123spam456spam789"|cut:"spam" }} 查找删除指定字符串
    
    	{{ value|date:"F j, Y" }} 格式化日期
    
    	{{ value|default:"(N/A)" }} 值不存在,使用指定值
    
    	{{ value|default_if_none:"(N/A)" }} 值是None,使用指定值
    
    	{{ 列表变量|dictsort:"数字" }} 排序从小到大
    
    	{{ 列表变量|dictsortreversed:"数字" }} 排序从大到小
    
    	{% if 92|pisibleby:"2" %} 判断是否整除指定数字
    
    	{{ string|escape }} 转换为html实体
    
    	{{ 21984124|filesizeformat }} 以1024为基数,计算最大值,保留1位小数,增加可读性
    
    	{{ list|first }} 返回列表第一个元素
    
    	{{ "ik23hr&jqwh"|fix_ampersands }} &转为&
    
    	{{ 13.414121241|floatformat }} 保留1位小数,可为负数,几种形式
    
    	{{ 13.414121241|floatformat:"2" }} 保留2位小数
    
    	{{ 23456 |get_digit:"1" }} 从个位数开始截取指定位置的1个数字
    
    	{{ list|join:", " }} 用指定分隔符连接列表
    
    	{{ list|length }} 返回列表个数
    
    	{% if 列表|length_is:"3" %} 列表个数是否指定数值
    
    	{{ "ABCD"|linebreaks }} 用新行用 标记包裹
    
    	{{ "ABCD"|linebreaksbr }} 用新行用 标记包裹
    
    	{{ 变量|linenumbers }} 为变量中每一行加上行号
    
    	{{ "abcd"|ljust:"50" }} 把字符串在指定宽度中对左,其它用空格填充
    
    	{{ "ABCD"|lower }} 小写
    
    	{% for i in "1abc1"|make_list %}ABCDE,{% endfor %} 把字符串或数字的字符个数作为一个列表
    
    	{{ "abcdefghijklmnopqrstuvwxyz"|phone2numeric }} 把字符转为可以对应的数字??
    
    	{{ 列表或数字|pluralize }} 单词的复数形式,如列表字符串个数大于1,返回s,否则返回空串
    
    	{{ 列表或数字|pluralize:"es" }} 指定es
    
    	{{ 列表或数字|pluralize:"y,ies" }} 指定ies替换为y
    
    	{{ object|pprint }} 显示一个对象的值
    
    	{{ 列表|random }} 返回列表的随机一项
    
    	{{ string|removetags:"br p p" }} 删除字符串中指定html标记
    
    	{{ string|rjust:"50" }} 把字符串在指定宽度中对右,其它用空格填充
    
    	{{ 列表|slice:":2" }} 切片
    
    	{{ string|slugify }} 字符串中留下减号和下划线,其它符号删除,空格用减号替换
    
    	{{ 3|stringformat:"02i" }} 字符串格式,使用Python的字符串格式语法
    
    	{{ "EABCD"|striptags }} 剥去[X]HTML语法标记
    
    	{{ 时间变量|time:"P" }} 日期的时间部分格式
    
    	{{ datetime|timesince }} 给定日期到现在过去了多少时间
    
    	{{ datetime|timesince:"other_datetime" }} 两日期间过去了多少时间
    
    	{{ datetime|timeuntil }} 给定日期到现在过去了多少时间,与上面的区别在于2日期的前后位置。
    
    	{{ datetime|timeuntil:"other_datetime" }} 两日期间过去了多少时间
    
    	{{ "abdsadf"|title }} 首字母大写
    
    	{{ "A B C D E F"|truncatewords:"3" }} 截取指定个数的单词
    
    	{{ "111221"|truncatewords_html:"2" }} 截取指定个数的html标记,并补完整
    
    	{{ list|unordered_list }}多重嵌套列表展现为html的无序列表
    
    	{{ string|upper }} 全部大写
    
    	linkage url编码
    	{{ string|urlize }} 将URLs由纯文本变为可点击的链接。 
    
    	{{ string|urlizetrunc:"30" }} 同上,多个截取字符数。 
    
    	{{ "B C D E F"|wordcount }} 单词数
    
    	{{ "a b c d e f g h i j k"|wordwrap:"5" }} 每指定数量的字符就插入回车符
    
    	{{ boolean|yesno:"Yes,No,Perhaps" }} 对三种值的返回字符串,对应是 非空,空,None。
    
    
  • models filter筛选条件
  • 	条件选取querySet的时候,filter表示=,exclude表示!=。
    	querySet.distinct() 去重复
    	__exact 精确等于 like 'aaa'
    	 __iexact 精确等于 忽略大小写 ilike 'aaa'
    	 __contains 包含 like '%aaa%'
    	 __icontains 包含 忽略大小写 ilike '%aaa%',但是对于sqlite来说,contains的作用效果等同于icontains。
    	__gt 大于
    	__gte 大于等于
    	__lt 小于
    	__lte 小于等于
    	__in 存在于一个list范围内
    	__startswith 以...开头
    	__istartswith 以...开头 忽略大小写
    	__endswith 以...结尾
    	__iendswith 以...结尾,忽略大小写
    	__range 在...范围内
    	__year 日期字段的年份
    	__month 日期字段的月份
    	__day 日期字段的日
    	__isnull=True/False
    
    	例q1.filter(pub_date__gte=datetime.date.today())表示为时间>=now,q1.exclude(pub_date__gte=datetime.date.today())表示为<=now
    	“在django models中取得一个字段的distinct值”。就是select distinct xxx from table_name ...这样的功能。使用values会生成ValuesQuerySet(形如N个dict组成的list),猜测大数据无额外性能影响,毕竟queryset系列都是使用时才查询操作的。
    	xxxx.objects.values("field_name").distinct() 或者 xxxx.objects.distinct().values("field_name")
    
  • HttpResponse
  • 一、使用方法
      1.传递一个字符串#
        最简单的方式是传递一个字符串作为页面的内容到HttpResponse构造函数,并返回给用户:
    
    from django.http import HttpResponse
    response = HttpResponse("Here's the text of the Web page.")
    response = HttpResponse("Text only,please.",content_type="text/plain")
        可以将response看做一个类文件对象,使用write()方法不断地往里面添加内容。
    
    response = HttpResponse()
    response.write("

    Here's the text of the Web page.

    ") response.write("

    Here's another paragraph.

    ")   2.传递可迭代对象#     HttpResponse会立即处理这个迭代器,并把它的内容存成字符串,最后废弃这个迭代器。比如文件在读取后,会立刻调用close()方法,关闭文件。   3.设置头部字段#     可以把HttpResponse对象当作一个字典一样,在其中增加和删除头部字段。 response = HttpResponse() response['Age'] = 120 del response['Age']     注意!与字典不同的是,若要删除的头部字段不存在,del不会抛出KeyError异常。     HTTP的头部字段中不能包含换行。所以如果我们提供的头部字段值包含换行符(CR或者LF),将会抛出BadHeaderError异常。   4.告诉浏览器将响应视为文件附件#     让浏览器以文件附件的形式处理响应,需要声明content_type类型和设置Content-Disposition头信息。 例如,给浏览器返回一个微软电子表格: response = HttpResponse(my_data, content_type='application/vnd.ms-excel') response['Content-Disposition'] = 'attachment; filename="foo.xls"' 二、属性   1.HttpResponse.content#     响应的内容。bytes类型。   2.HttpResponse.charset#     编码的字符集。 如果没指定,将会从content_type中解析出来。   3.HttpResponse.status_code#     响应的状态码,比如200。   4.HttpResponse.reason_phrase#     响应的HTTP原因短语。 使用标准原因短语。除非明确设置,否则reason_phrase由status_code的值决定。   5.HttpResponse.streaming#     这个属性的值总是False。由于这个属性的存在,使得中间件能够区别对待流式响应和常规响应。   6.HttpResponse.closed#     如果响应已关闭,那么这个属性的值为True。 三、方法   1.HttpResponse.init(content='', content_type=None, status=200, reason=None, charset=None)[source]#     响应的实例化方法。使用content参数和content-type实例化一个HttpResponse对象。     content应该是一个迭代器或者字符串。如果是迭代器,这个迭代期返回的应是一串字符串,并且这些字符串连接起来形成response的内容。 如果不是迭代器或者字符串,那么在其被接收的时候将转换成字符串。     content_type是可选地,用于填充HTTP的Content-Type头部。如果未指定,默认情况下由DEFAULT_CONTENT_TYPE和DEFAULT_CHARSET设置组成:text/html; charset=utf-8。     status是响应的状态码。reason是HTTP响应短语。charset是编码方式。   2.HttpResponse.has_header(header)#     检查头部中是否有给定的名称(不区分大小写),返回True或 False。   3.HttpResponse.setdefault(header, value)#     设置一个头部,除非该头部已经设置过了。   4.HttpResponse.set_cookie(key, value='', max_age=None, expires=None, path='/', domain=None, secure=None, httponly=False)#     设置一个Cookie。 参数与Python标准库中的Morsel.Cookie对象相同。     max_age: 生存周期,以秒为单位。     expires:到期时间。     domain: 用于设置跨域的Cookie。例如domain=".lawrence.com"将设置一个www.lawrence.com、blogs.lawrence.com和calendars.lawrence.com都可读的Cookie。 否则,Cookie将只能被设置它的域读取。     如果你想阻止客服端的JavaScript访问Cookie,可以设置httponly=True。   5. HttpResponse.set_signed_cookie(key, value, salt='', max_age=None, expires=None, path='/', domain=None, secure=None, httponly=True)#     与set_cookie()类似,但是在设置之前将对cookie进行加密签名。通常与HttpRequest.get_signed_cookie()一起使用。   6.HttpResponse.delete_cookie(key, path='/', domain=None)#     删除Cookie中指定的key。由于Cookie的工作方式,path和domain应该与set_cookie()中使用的值相同,否则Cookie不会删掉。   7.HttpResponse.write(content)[source]#     将HttpResponse实例看作类似文件的对象,往里面添加内容。   8.HttpResponse.flush()#     清空HttpResponse实例的内容。   9.HttpResponse.tell()[source]#     将HttpResponse实例看作类似文件的对象,移动位置指针。   10.HttpResponse.getvalue()[source]#     返回HttpResponse.content的值。 此方法将HttpResponse实例看作是一个类似流的对象。   11.HttpResponse.writelines(lines)[source]#     将一个包含行的列表写入响应对象中。 不添加分行符。 四、HttpResponse的子类   Django包含了一系列的HttpResponse衍生类(子类),用来处理不同类型的HTTP响应。与HttpResponse相同, 这些衍生类存在于django.http之中。     ·class HttpResponseRedirect[source]:重定向,返回302状态码。已经被redirect()替代。     ·class HttpResponsePermanentRedirect[source]:永久重定向,返回301状态码。     ·class HttpResponseNotModified[source]:未修改页面,返回304状态码。     ·class HttpResponseBadRequest[source]:错误的请求,返回400状态码。     ·class HttpResponseNotFound[source]:页面不存在,返回404状态码。     ·class HttpResponseForbidden[source]:禁止访问,返回403状态码。     ·class HttpResponseNotAllowed[source]:禁止访问,返回405状态码。     ·class HttpResponseGone[source]:过期,返回405状态码。     ·class HttpResponseServerError[source]:服务器错误,返回500状态码。 五、JsonResponse类   class JsonResponse(data,encoder = DjangoJSONEncoder,safe = True,json_dumps_params = None ,** kwargs)[source]   JsonResponse是HttpResponse的一个子类,是Django提供的用于创建JSON编码类型响应的快捷类。   它从父类继承大部分行为,并具有以下不同点:     它的默认Content-Type头部设置为application/json。     它的第一个参数data,通常应该为一个字典数据类型。 如果safe参数设置为False,则可以是任何可JSON 序列化的对象。   encoder默认为django.core.serializers.json.DjangoJSONEncoder,用于序列化数据。   布尔类型参数safe默认为True。 如果设置为False,可以传递任何对象进行序列化(否则,只允许dict 实例)。   典型的用法如下: from django.http import JsonResponse response = JsonResponse({'foo': 'bar'}) response.content   若要序列化非dict对象,必须设置safe参数为False: response = JsonResponse([1, 2, 3], safe=False)   如果不传递safe=False,将抛出一个TypeError。   如果你需要使用不同的JSON 编码器类,可以传递encoder参数给构造函数: response = JsonResponse(data, encoder=MyJSONEncoder) 六、StreamingHttpResponse类   StreamingHttpResponse类被用来从Django响应一个流式对象到浏览器。如果生成的响应太长或者是占用的内存较大,这么做可能更有效率。 例如,它对于生成大型的CSV文件非常有用。   StreamingHttpResponse不是HttpResponse的衍生类(子类),因为它实现了完全不同的应用程序接口。但是,除了几个明显不同的地方,两者几乎完全相同。 七、FileResponse   文件类型响应。通常用于给浏览器返回一个文件附件。   FileResponse是StreamingHttpResponse的衍生类,为二进制文件专门做了优化。   FileResponse需要通过二进制模式打开文件,如下: from django.http import FileResponse response = FileResponse(open('myfile.png', 'rb'))