下面是从弹性搜索中获取一些数据并将该数据导出到名为'mycsvfile'的csv文件的代码。如何打印出从弹性搜索导出的CVS文件中的列名?
我想更改列名以便它可以被人读取。
下面是代码:
from elasticsearch import Elasticsearch
import csv
es = Elasticsearch(["9200"])
# Replace the following Query with your own Elastic Search Query
res = es.search(index="search", body=
{
"_source": ["DTDT", "TRDT", "SPLE", "RPLE"],
"query": {
"bool": {
"should": [
{"wildcard": {"CN": "TEST1"}}
]
}
}
}, size=10)
with open('mycsvfile.csv', 'w') as f: # Just use 'w' mode in 3.x
header_present = False
for doc in res['hits']['hits']:
my_dict = doc['_source']
if not header_present:
w = csv.DictWriter(f, my_dict.keys())
w.writeheader()
header_present = True
w.writerow(my_dict)
当我运行上面的查询的CSV文件中的数据看起来象下面这样:
DTDT TRDT SPLE SACL RPLE
20170512 12/05/2017 15:39 1001 0 0
20170512 12/05/2017 15:39 1001 0 0
20170908 08/09/2017 02:42 1001 0 0
20170908 08/09/2017 06:30 1001 0 0
正如你所看到的列名是一样的查询,并且我想在生成文件时给它们可读的名称。
有人可以显示并修复我的代码,以便将列名输入到CSV文件中吗?
谢谢你提前
你的问题很难理解。您的意思是您对“DTDT”不满意,并且您希望为此专栏指定不同的名称,例如“日期”? – Wli
正确,我想命名像日期等列等抱歉的困惑,你可以编辑我的代码,并告诉我如何做到这一点? – Rich
为了清晰起见,我编辑了您的问题并回答了它。 – Wli