我想使用elasticsearch-dsl 0.0.9 librairy但是他们的例子已经过时了。 我安装了最新版本,并且不再存在Integer和Boolean类型。
因此他们的例子不起作用。
from datetime import datetime
#There is no 'Integer' in elasticsearch_dsl
from elasticsearch_dsl import DocType, String, Date, Integer
from elasticsearch_dsl.connections import connections
# Define a default Elasticsearch client
connections.create_connection(hosts=['localhost'])
class Article(DocType):
title = String(analyzer='snowball', fields={'raw': String(index='not_analyzed')})
body = String(analyzer='snowball')
tags = String(index='not_analyzed')
published_from = Date()
lines = Integer() ############################## HERE
有人知道如何声明整数字段吗?
感谢。
根据此文档https://media.readthedocs.org/pdf/elasticsearch-dsl/latest/elasticsearch-dsl.pdf,整数类型仍应在0.0.9
中可用我不知道为什么它找不到它。
正如您从我的点子输出中看到的,我确实安装了0.0.9:Downloading elasticsearch_dsl-0.0.9-py2.py3-none-any.whl
答案 0 :(得分:3)
Float,Double,Byte,Integer,Boolean,IP等字段类型是elasticsearch-dsl
中的动态类。库本身创建了源代码中提到的这些类。在此处发布文件中的示例代码以供快速参考。要获得完整的参考,您可以查看文件elasticsearch_dsl/field.py
。
# generate the query classes dynamicaly
for f in FIELDS:
fclass = _make_dsl_class(Field, f)
globals()[fclass.__name__] = fclass
__all__.append(fclass.__name__)
FIELDS是一个包含所有这些字段类型的元组。所以基本上回答你的问题,你的IDE会将类显示为不可用,但是当你运行代码时,它们将自动创建。
从第212行检查here。