我目前正在使用带有大型数据库的Flask Web应用程序,这意味着我不得不放弃最初为WhooshAlchemy编写的代码。第一次测试时,出现以下错误。
Post.query.whoosh_search('phone').all()
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "C:\Users\Abdul\Anaconda3\lib\site-packages\flask_whooshalchemy.py", line 103, in whoosh_search
if not isinstance(query, unicode):
NameError: name 'unicode' is not defined
这与python 3重命名Unicode几年前有什么关系吗,还是其他吗?我尝试将Unicode更改为str,但这似乎无法解决问题?任何有用的输入将不胜感激。
免责声明:不再支持Flask_whooshalchemy,并且不适用于python 3.0 +。
解决方案:您必须使用自定义解决方案或使用效果很好的Flask m-search。
这里是flask m-search的链接,以防万一有人遇到相同的问题。
一个简单的例子如下:
from flask import Flask
from flask_sqlalchemy import SQLAlchemy
from flask_msearch import Search
app = Flask(__name__)
app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:////tmp/test.db'
db = SQLAlchemy(app)
search = Search()
search.init_app(app)
class User(db.Model):
__searchable__ = ['id', 'username', 'email']
id = db.Column(db.Integer, primary_key=True)
username = db.Column(db.String(80), unique=True, nullable=False)
email = db.Column(db.String(120), unique=True, nullable=False)
def __repr__(self):
return '<User %r>' % self.username