1.  动态路由的匹配器?

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

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

  1. 动态路由本身,可以传任何参数字符串或者数字,如:<username>
  2. 只能传整形数字,如:<int:user_id>
  3. 只能传浮点型数字,如:<float:num>
  4. 只能传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入门之自定义过滤器(匹配器)的更多相关文章

  1. Flask基础(14)-->自定义过滤器

    Flask基础(13)-->自定义过滤器 什么是过滤器? 过滤器的本质就是函数.有时候我们不仅仅只是需要输出变量的值,我们还需要修改变量的显示,甚至格式化.运算等等,而在模板中是不能直接调用 P ...

  2. EassyMock实践 自定义参数匹配器

    虽然easymock中提供了大量的方法来进行参数匹配,但是对于一些特殊场合比如参数是复杂对象而又不能简单的通过equals()方法来比较,这些现有的参数匹配器就无能为力了.easymock为此提供了I ...

  3. Flask入门学习——自定义一个url转换器

          我们知道,flask的url规则是可以添加变量部分的,这个参数变量是写在尖括号里的,比如:/item/<id>/,如果需要指出参数的类型要符合<converter:vai ...

  4. Mockito 2 参数匹配器

    Mockito 通过使用 equals() 这种自然的 Java 样式来校验参数值.有时候,当需要有其他一些灵活性的时候,你可能会要求使用参数匹配(argument matchers). 请参考下面的 ...

  5. Hamcrest匹配器框架

    其实在之前的文章中已经使用过 Hamcrest 匹配器框架,本篇文章将系统的介绍它的使用. 为什么要用Hamcrest匹配器框架 Hamcrest是一款软件测试框架, 可以通过现有的匹配器类检查代码中 ...

  6. Flask 自定义过滤器多个参数传入

    非完整HTML文件: <div class="container" style="margin-top:50px;"> <div class= ...

  7. flask第二十四篇——模板【6】自定义过滤器

    请关注孟船长的公众号:自动化测试实战 大家想了解其他过滤器可以参考这里: http://jinja.pocoo.org/docs/dev/templates/#builtin-filters ---- ...

  8. flask框架下的jinja2模板引擎(2)(过滤器与自定义过滤器)

    flask框架下的jinja2模块引擎(1):https://www.cnblogs.com/chichung/p/9774556.html 这篇论文主要用来记录下 jinja2 的过滤器. 什么是过 ...

  9. flask的自定义过滤器

    过滤器的本质是函数.当模板内置的过滤器不能满足需求,可以自定义过滤器.自定义过滤器有两种实现方式: 一种是通过Flask应用对象的 add_template_filter 方法 通过装饰器来实现自定义 ...

随机推荐

  1. 理解WebKit和Chromium: 硬件加速之RenderLayer树到合成树

    转载请注明原文地址:http://blog.csdn.net/milado_nju ## 概述 在前面的章节中,笔者介绍了WebKit渲染引擎是如何有HTML网页构建DOM树.RenderObject ...

  2. Material Design之RecyclerView的使用(一)

    Android 5.0开始就推荐使用Material Design这个设计语言,本文开始就逐一讲解Material Design中控件的使用.本章主要讲解RecyclerView,期中会带有ToolB ...

  3. (十八)TableView实践(多组汽车品牌展示)

    对于多组数据,可能会用到模型的嵌套. 例如多组汽车,每组是一个模型,组内有多辆车的信息,每辆车的信息也是一个模型,相当于模型中有模型. 可以看到,每个item是一个字典,这要创建一个模型,而模型内部的 ...

  4. 《java入门第一季》之eclipse快捷键

    Eclipse快捷键大全(转载) Ctrl+1 快速修复(最经典的快捷键,就不用多说了) Ctrl+D: 删除当前行 Ctrl+Alt+↓ 复制当前行到下一行(复制增加) Ctrl+Alt+↑ 复制当 ...

  5. Leetcode_223_Rectangle Area

    本文是在学习中的总结,欢迎转载但请注明出处:http://blog.csdn.net/pistolove/article/details/46868363 Find the total area co ...

  6. Android回调详解

         很多时候开发遇到一些Ui更新 网络数据获取,或者方法方法传递的时候会借助回调函数,那么什么是回调函数 百度百科是这么解释的  转载请标注出处 http://blog.csdn.net/sk7 ...

  7. 【43】Activity的几种LaunchMode及使用场景

    standard 模式 这是默认模式,每次激活Activity时都会创建Activity实例,并放入任务栈中.使用场景:大多数Activity. singleTop 模式 如果在任务的栈顶正好存在该A ...

  8. butternife Zelezny自动注入插件

    插件地址:http://plugins.jetbrains.com/plugin/7369 Products: IntelliJ IDEA, RubyMine, WebStorm, PhpStorm, ...

  9. 【基础】CSS实现多重边框的5种方式

    简言 目前最优雅地实现多重边框的方案是利用CSS3 的 box-shadow属性,但如果要兼容老的浏览器,则需要选择其它的方案.本文简要地列举了几种多重边框的实现方案,大家可以根据项目实际及兼容性要求 ...

  10. JavaScript继承详解

    面向对象与基于对象 在传统面向对象的语言中,有两个非常重要的概念 - 类和实例. 类定义了一类事物公共的行为和方法:而实例则是类的一个具体实现. 我们还知道,面向对象编程有三个重要的概念 - 封装.继 ...