我想捕获以前缀id
开头的所有网址,以便以下示例匹配:/stuff
,/users
和/users/
。目前我写了多个规则来匹配一切。有没有办法写一条规则来匹配我想要的东西?
/users/604511/edit
答案 0 :(得分:2)
将多个规则分配给同一端点是合理的。这是最直接的解决方案。
如果你想要一个规则,你可以写一个custom converter来捕获空字符串或以斜杠开头的任意数据。
from flask import Flask
from werkzeug.routing import BaseConverter
class WildcardConverter(BaseConverter):
regex = r'(|/.*?)'
weight = 200
app = Flask(__name__)
app.url_map.converters['wildcard'] = WildcardConverter
@app.route('/users<wildcard:path>')
def users(path):
return path
c = app.test_client()
print(c.get('/users').data) # b''
print(c.get('/users-no-prefix').data) # (404 NOT FOUND)
print(c.get('/users/').data) # b'/'
print(c.get('/users/400617/edit').data) # b'/400617/edit'
如果您确实希望匹配带有/users
前缀的任何,例如/users-no-slash/test
,请将规则更改为更宽松:regex = r'.*?'
。