我正在学习 Python,并试图将 GitHub 问题转换为可读的形式。使用有关 如何将 JSON 转换为 CSV 的建议? ,我想出了这个:
import json
import csv
f = open('issues.json')
data = json.load(f)
f.close()
f = open("issues.csv", "wb+")
csv_file = csv.writer(f)
csv_file.writerow(["gravatar_id", "position", "number", "votes", "created_at", "comments", "body", "title", "updated_at", "html_url", "user", "labels", "state"])
for item in data:
csv_file.writerow([item["gravatar_id"], item["position"], item["number"], item["votes"], item["created_at"], item["comments"], item["body"], item["title"], item["updated_at"], item["html_url"], item["user"], item["labels"], item["state"]])
其中“issues.json”是包含我的 GitHub 问题的 JSON 文件。当我尝试运行它时,我得到
File "foo.py", line 14, in <module>
csv_file.writerow([item["gravatar_id"], item["position"], item["number"], item["votes"], item["created_at"], item["comments"], item["body"], item["title"], item["updated_at"], item["html_url"], item["user"], item["labels"], item["state"]])
TypeError: string indices must be integers
我在这里想念什么?哪些是“字符串索引”?我敢肯定,一旦我得到这个工作,我会有更多的问题,但现在,我只是喜欢这个工作!
当我将 for
语句调整为简单
for item in data:
print item
我得到的是……“问题” - 所以我正在做一些更基本的错误。这是我的一些 JSON 内容:
{"issues": [{"gravatar_id": "44230311a3dcd684b6c5f81bf2ec9f60", "position": 2.0, "number": 263, "votes": 0, "created_at": "2010/09/17 16:06:50 -0700", "comments": 11, "body": "Add missing paging (Older>>) links...
当我打印 data
时,它看起来真的很奇怪:
{u'issues': [{u'body': u'Add missing paging (Older>>) lin...
原文由 Amanda 发布,翻译遵循 CC BY-SA 4.0 许可协议
item
很可能是您代码中的字符串;字符串索引是方括号中的索引,例如gravatar_id
。所以我首先检查你的data
变量,看看你在那里收到了什么;我猜data
是一个字符串列表(或者至少是一个包含至少一个字符串的列表),而它应该是一个字典列表。