使用elasticsearch-dsl创建一个带有Integer字段的DocType类

时间:2015-11-17 14:16:43

标签: python-2.7 elasticsearch elasticsearch-dsl

我想使用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

1 个答案:

答案 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