0

抱歉,标题类型重复。我有一个问题发现和如何做到这一点的例子。我有一个从 Zendesk 提取的 json 文件。我正在做一个 json.dumps 来把它变成一个可读的格式和一个 python 字典。我在 for 循环中有以下内容,因此我可以从 json 文件中获取所需的信息并将其写入 csv 文件。

for item in data['results']:
    print(
        item['id'] ,item['via']['channel'], item['via']['source']['from'], item['subject'], item['tags'],
        item['created_at'], item['status'], item['custom_fields'][12], item['custom_fields'][12]['value'],
        item['result_type'], item['priority']

从这段代码中,我得到了我想要的带有正确信息的项目。

我尝试了以下方法将其打印到文件中,但我在文件中返回的只是最后一条记录

import csv

with open('file.txt', 'w') as file:

csv_app = csv.writer(file)
for item in python_data['results']:
    csv_app.writerows(item['id'], item['via']['channel'],item['via']['source']['from'],item['subject'], item['tags'],
           item['created_at'], item['status'], item['custom_fields'][12], item['custom_fields'][12]['value'],
           item['priority'], item['result_type'])

我想得到一些关于如何获得所有东西的建议(我已经尝试了很多东西)还有一个项目['via']['source']['from']['name'] 我已经取出因为它在没有价值时会导致错误。我如何在一个字段的基础上处理这个我假设一个 if 条件。

任何帮助或指出我正确的方向将不胜感激。

提前致谢。

4

1 回答 1

0

首先,file是python中的保留字。使用其他东西,例如for fout

其次,使用writerow代替writerows.

第三,在你的例子中你的缩进是关闭的(最后五行应该缩进一级)。

import csv

data = {'results': [{'A': 1, 'B': 2, 'C': 3}, 
                    {'A': 10, 'B': 20, 'C': 30}]}
with open('test.txt', 'w') as f:
    csv_app = csv.writer(f)
    for item in data['results']:
        csv_app.writerow([item[x] for x in ['A', 'B', 'C']])

$ cat test.txt
1,2,3
10,20,30
于 2017-11-28T18:38:59.927 回答