flask自定义过滤器

1.  动态路由的匹配器?

  不知道这种叫啥名,啥用法,暂且叫做匹配器吧。

  Flask自带的匹配器可以说有四种吧(保守数字,就我学到的)

  1. 动态路由本身,可以传任何参数字符串或者数字,如:<username>
  2. 只能传整形数字,如:<int:user_id>
  3. 只能传浮点型数字,如:<float:num>
  4. 只能传path路径,如:<path:url>

  举个例子  

复制代码
 1 from flask import Flask
 2 
 3 app = Flask(__name__)
 4 
 5 @app.route('/user/<int:user_id>'
 6 def user(user_id):
 7     return 'Hello,%d' %user_id
 8 
 9 if __name__ == '__main__':
10     app.run(debug=True)
复制代码

  这个user的路由只能响应整型的数字路径,不能输入字符串的

  

  当然上面的很简单,接下来,我要定义一个使用更广泛,功能更强大的

  正则匹配器  

复制代码
 1 #coding:utf-8
 2 
 3 from flask import Flask
 4 from werkzeug.routing import BaseConverter
 5 
 6 #定义正则转换器的类
 7 class RegexConverter(BaseConverter):
 8     def __init__(self,url_map,*items):
 9         super(RegexConverter, self).__init__(url_map)
10         self.regex=items[0]
11 
12 app = Flask(__name__)
13 #实例化
14 app.url_map.converters['regex']=RegexConverter
15 
16 @app.route('/user/<regex("([a-z]|[A-Z]){4}"):username>', methods=['POST', 'GET'])
17 def user(username):
18     return 'Hello,%s' % username
19 
20 if __name__ == '__main__':
21     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

复制代码
 1 # coding:utf-8
 2 
 3 from flask import Flask,render_template
 4 
 5 app = Flask(__name__)
 6 
 7 @app.route('/home')
 8 def hone():
 9     return render_template('index.html',title='## header 2')
10 
11 # 这里定义一个过滤器,取名为'md'
12 @app.template_filter('md')
13 def md_to_html(txt):
14     from markdown import  markdown
15     return markdown(txt)
16 
17 
18 if __name__ == '__main__':
19     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的文件并写入:

1
2
3
4
5
6
7
8
9
10
# 常见的HTTP方法
 
## GET
浏览器告知服务器:只获取页面的信息发给我
这是常用的方法
 
## POST
浏览器告知服务器:想在URL中发布新信息
并且,服务器必须确保数据已存储且只存储一次
这是HTML中发送表单数据到服务器的一种方法

  

  代码如下:

  #Sample.py

复制代码
 1 # coding:utf-8
 2 
 3 from flask import Flask,render_template
 4 
 5 app = Flask(__name__)
 6 
 7 @app.route('/home')
 8 def hone():
 9     return render_template('index.html',title='## header 2')
10 
11 @app.template_filter('md')
12 def md_to_html(txt):
13     from markdown import  markdown
14     return markdown(txt)
15 
16 def read_md_file(filename):
17     with open(filename) as md_file:
18         content = reduce(lambda x,y:x+y,md_file.readlines())
19     return content.decode('utf-8')
20 
21 # 注意:这里很重要,作用是把read_md_file()这个函数注册到所有的Jinjia模板中
22 # 不然html中会找不到这个函数而出错
23 @app.context_processor
24 def inject_methods():
25     return dict(read_md=read_md_file)
26 
27 # read_md是html使用的函数名,read_md_file是上面定义的函数名
28 
29 if __name__ == '__main__':
30     app.run(debug=True)
复制代码

 

 

  #index.html

复制代码
 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>Title</title>
 6 </head>
 7 <body>
 8     {{ read_md('http_methods.md')|md|safe }}
 9 </body>
10 </html>
复制代码

  运行,结果如下

已经打到我们想要的效果@@

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值