flask 貌似很少全文搜索的插件,有一个Flask-WhooshAlchemy,但试了几次都用不了,所以参考 Flask-WhooshAlchemy 自己写了一个
插件基于 whoosh,纯 python 编写,使用上很简单
from flask_msearch import Search
[...]
search = Search()
search.init_app(app)
# models.py
class Post(db.Model):
__tablename__ = 'post'
__searchable__ = ['title', 'content']
# views.py
@app.route("/search")
def w_search():
keyword = request.args.get('keyword')
results = search.whoosh_search(Post,query=keyword,fields=['title'],limit=20)
return ''
如果要对已存在的数据创建索引
search.create_index()
自定义 analyzer
from jieba.analyse import ChineseAnalyzer
search = Search(analyzer=ChineseAnalyzer())
项目地址:https://github.com/honmaple/flask-msearch
可以查看演示:demo
(还有更多 whoosh 的功能还没加上)
1
pathbox 2017-04-16 19:32:47 +08:00
简单的项目 可以用用。 其他 还是上 ES 吧
|
2
clino 2017-04-16 20:06:42 +08:00 via Android
然而搜标题美国并没有结果
|
3
awanabe 2017-04-16 20:14:11 +08:00
分词 建议用 jieba
ChineseAnalyzer 很弱 |
6
honmaple OP |
7
honmaple OP @awanabe ChineseAnalyzer 就是使用 jieba 实现的啊,不过使用 jieba 检索速度会有所下降
|
9
honmaple OP @clino 因为 jieba 是在每次使用时加载,而不是保存到内存中,使用时可以看出有明显的停顿
``` Building prefix dict from the default dictionary ... Loading model from cache /tmp/jieba.cache Loading model cost 1.450 seconds. Prefix dict has been built succesfully. ``` |
10
honmaple OP 不好意思,我刚才再次验证了一下, jieba 只在第一次使用时会从 cache 中加载,之后就保存到内存中了,使用 jieba 对检索速度没有太大影响
|