Flask入门之自定义过滤器(匹配器)
1. 动态路由的匹配器?
不知道这种叫啥名,啥用法,暂且叫做匹配器吧。
Flask自带的匹配器可以说有四种吧(保守数字,就我学到的)
- 动态路由本身,可以传任何参数字符串或者数字,如:<username>
- 只能传整形数字,如:<int:user_id>
- 只能传浮点型数字,如:<float:num>
- 只能传path路径,如:<path:url>
举个例子
from flask import Flask app = Flask(__name__) @app.route('/user/<int:user_id>'
def user(user_id):
return 'Hello,%d' %user_id if __name__ == '__main__':
app.run(debug=True)
这个user的路由只能响应整型的数字路径,不能输入字符串的
当然上面的很简单,接下来,我要定义一个使用更广泛,功能更强大的
正则匹配器
#coding:utf-8 from flask import Flask
from werkzeug.routing import BaseConverter #定义正则转换器的类
class RegexConverter(BaseConverter):
def __init__(self,url_map,*items):
super(RegexConverter, self).__init__(url_map)
self.regex=items[0] app = Flask(__name__)
#实例化
app.url_map.converters['regex']=RegexConverter @app.route('/user/<regex("([a-z]|[A-Z]){4}"):username>', methods=['POST', 'GET'])
def user(username):
return 'Hello,%s' % username if __name__ == '__main__':
app.run(debug=True)
我们在转化器中规定,只能是四个英文字符才能被这个路由匹配,多余或者少于都不行
我们来看看效果,先输入Bikmin,五个字符,Not Found
再来输入正确的字符数字:Ming
现在已经成功@@
2. HTML中的过滤器
HTML中经常要使用各种转换器
最常见的就是safe了(这是自带的)
更多官方过滤器请查看: List of Builtin Filters
我们先举个safe的例子了解下这个过滤器是如何作用的
#Sample.py
@app.route('/home')
def hone():
return render_template('index.html',title='<h1>Hello,World!</h1>')
#index.html
<body>
{{ title }}
</body>
运行,输出如图
这是为什么呢?因为Jinjia2处于安全考虑,没有进行转义
这种情况下,我们就可以使用safe转化器了(自带的)
将#index.html 改为
<body>
{{ title|safe }}
</body>
再次运行,输出如图
附:上面这种情况除了过滤器起之外,还有另一种方法:块
#index.html
<body>
{% autoescape false %}
{{ title }}
{% endautoescape %}
</body>
同样的,我们也许需要自定义我们自己的过滤器
这里我们就自定义个,可以将markdown语法的文件进行转义输出到页面的过滤器
首先要先安装markdown这个库
pip install markdown
#Sample.py
# coding:utf-8 from flask import Flask,render_template app = Flask(__name__) @app.route('/home')
def hone():
return render_template('index.html',title='## header 2') # 这里定义一个过滤器,取名为'md'
@app.template_filter('md')
def md_to_html(txt):
from markdown import markdown
return markdown(txt) if __name__ == '__main__':
app.run(debug=True)
现在我们就可以使用md这个过滤器了
#index.html
<body>
{{ title|md }}
</body>
运行,查看结果
这时我们发现,markdown语法(##)已经转换成html格式的<h2>标签,说明起作用了
当然我们还需要用前面讲过的safe进行 转义
#index.html
<body>
{{ title|md|safe }}
</body>
至此,我们已经学会了如何自定义一个过滤器了
-------------------------------------------------以下内容,扩展,选择性学习-------------------------------------------------
在日常工作中,我们不能只对变量进行md转换吧?
我们可能会从一个文本中进行读取,然后渲染到html页面中
这时我们就要定义一个函数,读取文本内容到内存中,赋值给变量,在对其进行md转换。
首先我们要写一个markdown格式的文件,注意不要用notepad来写,读取的时候会有编码错误,调都调不回来
建议使用Pycharm来新建一个http_methods.md的文件并写入:
# 常见的HTTP方法 ## GET
浏览器告知服务器:只获取页面的信息发给我
这是常用的方法 ## POST
浏览器告知服务器:想在URL中发布新信息
并且,服务器必须确保数据已存储且只存储一次
这是HTML中发送表单数据到服务器的一种方法
代码如下:
#Sample.py
# coding:utf-8 from flask import Flask,render_template app = Flask(__name__) @app.route('/home')
def hone():
return render_template('index.html',title='## header 2') @app.template_filter('md')
def md_to_html(txt):
from markdown import markdown
return markdown(txt) def read_md_file(filename):
with open(filename) as md_file:
content = reduce(lambda x,y:x+y,md_file.readlines())
return content.decode('utf-8') # 注意:这里很重要,作用是把read_md_file()这个函数注册到所有的Jinjia模板中
# 不然html中会找不到这个函数而出错
@app.context_processor
def inject_methods():
return dict(read_md=read_md_file) # read_md是html使用的函数名,read_md_file是上面定义的函数名 if __name__ == '__main__':
app.run(debug=True)
#index.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
{{ read_md('http_methods.md')|md|safe }}
</body>
</html>
运行,结果如下
已经打到我们想要的效果@@
Flask入门之自定义过滤器(匹配器)的更多相关文章
- Flask基础(14)-->自定义过滤器
Flask基础(13)-->自定义过滤器 什么是过滤器? 过滤器的本质就是函数.有时候我们不仅仅只是需要输出变量的值,我们还需要修改变量的显示,甚至格式化.运算等等,而在模板中是不能直接调用 P ...
- EassyMock实践 自定义参数匹配器
虽然easymock中提供了大量的方法来进行参数匹配,但是对于一些特殊场合比如参数是复杂对象而又不能简单的通过equals()方法来比较,这些现有的参数匹配器就无能为力了.easymock为此提供了I ...
- Flask入门学习——自定义一个url转换器
我们知道,flask的url规则是可以添加变量部分的,这个参数变量是写在尖括号里的,比如:/item/<id>/,如果需要指出参数的类型要符合<converter:vai ...
- Mockito 2 参数匹配器
Mockito 通过使用 equals() 这种自然的 Java 样式来校验参数值.有时候,当需要有其他一些灵活性的时候,你可能会要求使用参数匹配(argument matchers). 请参考下面的 ...
- Hamcrest匹配器框架
其实在之前的文章中已经使用过 Hamcrest 匹配器框架,本篇文章将系统的介绍它的使用. 为什么要用Hamcrest匹配器框架 Hamcrest是一款软件测试框架, 可以通过现有的匹配器类检查代码中 ...
- Flask 自定义过滤器多个参数传入
非完整HTML文件: <div class="container" style="margin-top:50px;"> <div class= ...
- flask第二十四篇——模板【6】自定义过滤器
请关注孟船长的公众号:自动化测试实战 大家想了解其他过滤器可以参考这里: http://jinja.pocoo.org/docs/dev/templates/#builtin-filters ---- ...
- flask框架下的jinja2模板引擎(2)(过滤器与自定义过滤器)
flask框架下的jinja2模块引擎(1):https://www.cnblogs.com/chichung/p/9774556.html 这篇论文主要用来记录下 jinja2 的过滤器. 什么是过 ...
- flask的自定义过滤器
过滤器的本质是函数.当模板内置的过滤器不能满足需求,可以自定义过滤器.自定义过滤器有两种实现方式: 一种是通过Flask应用对象的 add_template_filter 方法 通过装饰器来实现自定义 ...
随机推荐
- 【一天一道LeetCode】#68. Text Justification
一天一道LeetCode 本系列文章已全部上传至我的github,地址:ZeeCoder's Github 欢迎大家关注我的新浪微博,我的新浪微博 欢迎转载,转载请注明出处 (一)题目 Given a ...
- Cocos2d中update与fixedUpdate的区别(五)
在真实情况中update:和fixedUpdate方法如何去调用? 由上所述,所以update方法在每帧被调用1次,从而给你一个机会去更新你的游戏对象的状态在其绘制之前.而fixedUpdate:方法 ...
- JavaScript进阶(三)常见工具(校验、通用)
JS常见工具(校验.通用) // 姓名校验 var checkName = function(name) { // 收货人姓名校验(准则:姓名为2-4汉字) var regu = /^[\u4E00- ...
- LIRe 源代码分析 2:基本接口(DocumentBuilder)
===================================================== LIRe源代码分析系列文章列表: LIRe 源代码分析 1:整体结构 LIRe 源代码分析 ...
- 为多态基类声明virtual析构函数
一个函数的返回值为基类指针,而当指针指向一个派生类对象,接下来派生类对象被这个基类指针删除的时候,就出现了局部销毁的问题.因为C++指出,当派生类经由一个基类指针被删除,而该基类指针带着一个non-v ...
- OAF更改动态头行
选择头信息,动态刷新行信息.本文将详细介绍该种需求的做法. 本例沿用<OAF-头行结构>的am与vo,所以在进行本例之前,请先完成<OAF-头行结构> 一.创建页面 在test ...
- Java中的50个关键字
form:http://blog.csdn.net/luoweifu/article/details/6776240 Java中的50个关键字 关键字也称为保留字,是指java语言中规定了特定含义的标 ...
- unix下各种查看“变量”的命令比较
子程序只会继承父程序的环境变量,而不继承其自定义变量. env 查看所有环境变量 set 查看所有变量,包括环境变量和自定义变量 set 还可以给程序位置参数赋值: set 1 2 3 将1赋值给$1 ...
- CF959F
题目大意:给定n个数,有Q次询问,每次询问由两个数l,x组成,表示前缀[1,l]构成的子序列有多少异或起来为x,个数%1e9+7 做法:考虑一个由x个数构成的线性基,如果这个线性基由Y个数构成,可以通 ...
- 《JUnit实战(第2版)》读书笔记
第1章 JUnit起步 主要了解JUnit,如何安装.运行JUnit 要点 JUnit4不需要像JUnit3那样extends TestCase类 Junit4基本都是用注解(该书都翻译为注释,但我喜 ...