我正在尝试使用请求向Flask-Restless发送过滤器查询。结果没有被过滤。如何正确地编写过滤器?
import requests
import json
q = {'filters': [{'task': 'build an API', 'task': 'profit'}]}
r = requests.get('http://127.0.0.1:5000/toworks', params={'q': json.dumps(q)})
我期望结果只包含第一个和第三个项目,但是第二个项目也出现了。
{
"towork1": {
"task": "build an API"
},
"towork2": {
"task": "?????"
},
"towork3": {
"task": "profit!"
}
}
您用于过滤器的语法完全错误。应该有一个过滤器列表,每个过滤器都是具有name
, op
和value
键的字典。由于您希望在任务的值中进行搜索,因此在筛选的值之前和之后使用带有通配符(%
)的like
op。您还需要使用or
,因为这两个过滤器是互斥的。
q = {'filters': [{'or': [
{'name': 'task', 'op': 'like', 'val': '%build%'},
{'name': 'task', 'op': 'like', 'val': '%profit%'}
]}]}