2,flask URL进阶
video5
flask特点:
1,为框架,简介,高扩展性。
2,flask相关依赖(jinja2,werkzeug)设计优秀。
3,开发高效,如SQL的ORM
video6 debug模式
我只推荐run->edit
video7 配置文件
1,文件方式
若文件路劲不带,可加silent让它在找不到路径时候也不报错。
2,常规方式
video8 URL中的两种传参
path可以接受‘/’。
可以接受多个‘/’的URL:
可以接受UUID:
全宇宙都唯一的随机数,可以做主键。
any:可以指定多种路径
1 @app.route('/<any(blog,user):url_path>/<id>') 2 def detail(url_path,id): 3 if url_path == 'blog': 4 return 'Blog:%s' %id 5 else: 6 return 'User:%s' %id
作用:不同的URL对应相同的视图函数就这么做。
video9 url_for
带参数的list函数中的page代入url_for的过程。
如果多带一个count呢?
则将以查询字符串的形式出现,结果为:
带参数的视图函数有个功能:
当你浏览一个网页想要评论的时候发现自己没登陆,等你登陆后又能回到你刚才要评论的页面,这种情况下可以实现通过url_for带参数的视图函数。
先用arg获取那个url后缀参数,通过url_for返到评论页面。
video10 自定义url_for转换器
转换器中已经存在int,float,string,UUID,path,any。那么我们定义一个电话号码的?
from werkzeug.routing import BaseConverter
在BaseConverter中Ctrl+B查看源代码:
发现一个父类: class BaseConverter(object) 而any继承了这个父类: class AnyConverter(BaseConverter): 且最后有一个对应关系: #: the default converter mapping for the map. DEFAULT_CONVERTERS = { 'default': UnicodeConverter, 'string': UnicodeConverter, 'any': AnyConverter, 'path': PathConverter, 'int': IntegerConverter, 'float': FloatConverter, 'uuid': UUIDConverter, }
也就是说我们自己可以定义一个:
class TelephoneConverter(BaseConverter):
电话转换器去继承父类,然后加入默认映射表中。
1 from flask import Flask 2 from werkzeug.routing import BaseConverter 3 4 app = Flask(__name__) 5 6 #url中限定手机号码的格式 7 class TelephoneConverter(BaseConverter): 8 regex = r'1[345678]\d{9}' 9 num_convert = int 10 app.url_map.converters['tel'] = TelephoneConverter 11 12 @app.route('/tel/<tel:my_tel>') 13 def gg(my_tel): 14 return '%s' %my_tel
第8行表示11位的电话号码。
第10行表示添加到默认映射表中。
结果为:
下面定义a+b形式的转换器:
先看代码:
1 #现有需求需要访问a、b两个板块的文章返回出来 2 from werkzeug.routing import BaseConverter 3 class ListConverter(BaseConverter): 4 def to_python(self, value): 5 return 'hahaha' 6 app.url_map.converters['list'] = ListConverter 7 8 @app.route('/list/<list:bankuai>') 9 def aabb(bankuai): 10 return '%s' %bankuai
再看结果:
我们发现这个to_python函数中的value实际上接受了url中的a+b,但是这个函数中我们的写法是不管传入什么我们都返回hahaha,所以页面上返回了hahaha。也就是说url中的值会经由to_python传给视图函数。to_url相反。
如果我们在to_python函数中写上别的东西呢?岂不是能实现我们想要的转换器?
1 #现有需求需要访问a、b两个板块的文章返回出来 2 from werkzeug.routing import BaseConverter 3 class ListConverter(BaseConverter): 4 def to_python(self, value): 5 return value.split('+') 6 app.url_map.converters['list'] = ListConverter 7 8 @app.route('/list/<list:bankuai>') 9 def aabb(bankuai): 10 return '%s' %bankuai
第5行是变化后的代码,效果如下:
再讲讲to_url。
1 from werkzeug.routing import BaseConverter 2 from flask import url_for 3 class ListConverter(BaseConverter): 4 def to_python(self, value): 5 return value.split('+') 6 def to_url(self, value): 7 print("value:",value) 8 return "+".join(value) 9 app.url_map.converters['list'] = ListConverter 10 11 @app.route('/list/<list:bankuai>') 12 def aabb(bankuai): 13 return '%s' %bankuai 14 15 @app.route('/') 16 def hello_world(): 17 print(url_for('aabb',bankuai=['d','c'])) 18 return 'to_url'
17的bankuai进入到to_url中,传进去的是['d','c'],所以第7行返回了这个值,然后return回“+”连接的dc,最终在url_for的时候就打印成了‘/list/d+c’
结果:
第一个值是7行的,第二个是17行的。
总结下:
video11 url_for小细节
先看代码块
1 @app.route('/list/') 2 def hello_world(): 3 return 'Hello World!'
再看效果:
我们发现我们在第1行list后带了个“/”,然后在浏览器输入时候带不带这个斜杠都能访问到。
再看不带斜杠的:
所以我们选择第一种,因为第二种方法中可能代码中没写url写了的时候会出故障。
get和post
video12 重定向详解
video13 关于响应(Response)
video29 加载静态文本
用url_for
video 30 模板继承
super继承了父模板中的文件。