2016-11-28 2 views
0

Я пытаюсь загрузить данные в elasticsearch 5, используя скрипт python csv2es.elasticsearch mapping no Ошибка объекта JSON

аргумент, переданный в csv2es, ссылается на json-файл с сопоставлениями elasticsearch. при загрузке отображения файла ниже:

{ 
"dynamic": "true", 
"properties": { 
    "username": {"type": “text”}, 
    "date": {"type": "date", "format" : "yyyy-MM-dd HH:mm"}, 
    "retweets": {"type": “integer”}, 
    "favourites": {"type": “integer”}, 
    "text": {"type": “text”}, 
    "geo": {"type": “keyword”}, 
    "mentions": {"type": “text”}, 
    "hashtags": {"type": “text”}, 
    "id": {"type": “keyword”}, 
    "permalink": {"type": “keyword”} 
    } 
} 

это выдает следующее сообщение об ошибке:

Applying mapping from: csv2es_mappings.json 
Traceback (most recent call last): 
    File "/usr/local/bin/csv2es", line 11, in <module> 
    sys.exit(cli()) 
    File "/usr/local/lib/python2.7/site-packages/click/core.py", line 664, in  __call__ 
return self.main(*args, **kwargs) 
File "/usr/local/lib/python2.7/site-packages/click/core.py", line 644, in main 
rv = self.invoke(ctx) 
File "/usr/local/lib/python2.7/site-packages/click/core.py", line 837, in  invoke 
return ctx.invoke(self.callback, **ctx.params) 
File "/usr/local/lib/python2.7/site-packages/click/core.py", line 464, in invoke 
return callback(*args, **kwargs) 
File "/usr/local/lib/python2.7/site-packages/csv2es.py", line 206, in cli 
mapping = json.loads(f.read()) 
File "/usr/local/Cellar/python/2.7.12/Frameworks/Python.framework/Versions/2.7/lib/python2.7/json/__init__.py", line 339, in loads 
return _default_decoder.decode(s) 
File "/usr/local/Cellar/python/2.7.12/Frameworks/Python.framework/Versions/2.7/lib/python2.7/json/decoder.py", line 364, in decode 
obj, end = self.raw_decode(s, idx=_w(s, 0).end()) 
File "/usr/local/Cellar/python/2.7.12/Frameworks/Python.framework/Versions/2.7/lib/python2.7/json/decoder.py", line 382, in raw_decode 
raise ValueError("No JSON object could be decoded") 
ValueError: No JSON object could be decoded 

Однако когда я загрузить следующий файл прогоны загрузки данных. Я использую text и keyword вместо string согласно указаниям для сопоставлений ES5 - при использовании string поля не подбираются и не индексируются должным образом.

{ 
"dynamic": "true", 
"properties": { 
    "username": {"type": "string"}, 
    "date": {"type": "date", "format" : "yyyy-MM-dd HH:mm"}, 
    "retweets": {"type": "string"}, 
    "favourites": {"type": "string"}, 
    "text": {"type": "string"}, 
    "geo": {"type": "string"}, 
    "mentions": {"type": "string"}, 
    "hashtags": {"type": "string"}, 
    "id": {"type": "string"}, 
    "permalink": {"type": "string"} 
    } 
} 

ответ

2

afaik, эта ошибка означает, что данные json недействительны. “text”, thats, окруженный left double quotation mark вместо .

Обновите свой python, чтобы вы могли видеть читаемую ошибку при декодировании строки json или использовать библиотеку simplejson.

Displaying better error message than "No JSON object could be decoded"

+0

отличные вещи, спасибо – joshi123