目录

Flask - 变量规则( Variable Rules)

通过向规则参数添加可变部分,可以动态构建URL。 此变量部分标记为《variable-name》 。 它作为关键字参数传递给与规则关联的函数。

在以下示例中, route()装饰器的rule参数包含附加到URL '/hello' 《name》变量部分。 因此,如果在浏览器中输入http://localhost:5000/hello/IoWiki作为URL ,则'TutorialPoint'将作为参数提供给hello()函数。

from flask import Flask
app = Flask(__name__)
@app.route('/hello/<name>')
def hello_name(name):
   return 'Hello %s!' % name
if __name__ == '__main__':
   app.run(debug = True)

将上面的脚本保存为hello.py并从Python shell运行它。 接下来,打开浏览器并输入URL http://localhost:5000/hello/IoWiki.

以下输出将显示在浏览器中。

Hello IoWiki!

除了默认的字符串变量部分,还可以使用以下转换器构建规则 -

Sr.No 转换器和描述
1

int

接受整数

2

float

对于浮点值

3

path

接受用作目录分隔符的斜杠

在以下代码中,使用了所有这些构造函数。

from flask import Flask
app = Flask(__name__)
@app.route('/blog/<int:postID>')
def show_blog(postID):
   return 'Blog Number %d' % postID
@app.route('/rev/<float:revNo>')
def revision(revNo):
   return 'Revision Number %f' % revNo
if __name__ == '__main__':
   app.run()

从Python Shell运行上面的代码。 访问浏览器中的URL http://localhost:5000/blog/11

给定的数字用作show_blog()函数的参数。 浏览器显示以下输出 -

Blog Number 11

在浏览器中输入此URL - http://localhost:5000/rev/1.1

revision()函数将浮点数作为参数。 浏览器窗口中显示以下结果 -

Revision Number 1.100000

Flask的URL规则基于Werkzeug’s路由模块。 这可确保形成的URL是唯一的,并且基于Apache规定的先例。

考虑以下脚本中定义的规则 -

from flask import Flask
app = Flask(__name__)
@app.route('/flask')
def hello_flask():
   return 'Hello Flask'
@app.route('/python/')
def hello_python():
   return 'Hello Python'
if __name__ == '__main__':
   app.run()

两个规则看起来都相似,但在第二个规则中,使用了斜杠(/) 。 结果,它成为规范的URL。 因此,使用/python/python/返回相同的输出。 但是,如果是第一个规则, /flask/ URL会导致404 Not Found页面。

↑回到顶部↑
WIKI教程 @2018