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 方法 通过装饰器来实现自定义 ...
随机推荐
- java线程池ThreadPoolExecutor 如何与 AsyncTask() 组合使用
简单说下Executors类,提供的一系列创建线程池的方法: 他们都有两个构造方法 1. --------newFixedThreadPool (创建一个定长线程池,可控制线程最大并发数,超出的线程会 ...
- 《java入门第一季》之ArrayList集合小案例
案例一:去除集合里面的重复元素 package cn.itcast_04; import java.util.ArrayList; /* * ArrayList去除集合中字符串的重复值(字符串的内容相 ...
- 《java入门第一季》之面向对象(修饰符的概念和总结)
还是由于eclipde等ide的强大功能,会自动提示你修饰符是否可行.所以对修饰符的作用了解即可: 修饰符: 权限修饰符:private,默认的,protected,public ...
- Eclipse搭建Android环境失败的解决方案
今天在Eclipse上搭建Android开发环境,不仅在安装ADT的过程中老是出错,而且Android SDK下载后,打开SDK Manager时也无法链接到网页下载tools,网上查了好多方法,试了 ...
- Xshell Linux 主要命令
1. 查看当前路径 pwd 2.列出当前目录的文件 ls 列出所有文件或者文件夹 ls *abc 列出以abc开头的所以文件 ls –l 列出所以文件及其详细详细 3.进入目录 cd ...
- FFMPEG结构体分析:AVFrame
注:写了一系列的结构体的分析的文章,在这里列一个列表: FFMPEG结构体分析:AVFrameFFMPEG结构体分析:AVFormatContextFFMPEG结构体分析:AVCodecContext ...
- Linux常用命令(第二版) --文件管理命令
文件管理命令 并不建议:照着像命令大全这类的书来学! 常用命令大约有200个. 文件命名规则: a)除了'/'之外所有字符都合法! b)这些字符最好不用 1.空格符,制表符,退格符 2.连接符 3.特 ...
- 运行Myeclipse时,如何删除IVM窗口
windows------>preference------>run/debug------->lauching--------->percpectives,改成never,n ...
- C语言之将无符号字符型转化为ascii码值
这个宏是在linux内核中获取的,主要的功能是能够将一个无符号字符型的参数转化为ASCII码值. ASCII : ASCII 编码里包括了128个字符.用 十进制 0 到 127 来表示 .那就对了 ...
- Github 错误合集:Failed connect to github.com:8080 || Failed connect to github.com:443; No error
文/skay 地址:http://blog.csdn.net/sk719887916/article/details/40541199 开发中遇到github无法pull和push代码问题,原来git ...