为什么我看到“TypeError:字符串索引必须是整数”?

新手上路,请多包涵

我正在学习 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 许可协议

阅读 642
2 个回答

item 很可能是您代码中的字符串;字符串索引是方括号中的索引,例如 gravatar_id 。所以我首先检查你的 data 变量,看看你在那里收到了什么;我猜 data 是一个字符串列表(或者至少是一个包含至少一个字符串的列表),而它应该是一个字典列表。

原文由 Tamás 发布,翻译遵循 CC BY-SA 3.0 许可协议

变量 item 是一个字符串。索引看起来像这样:

 >>> mystring = 'helloworld'
>>> print mystring[0]
'h'

上面的示例使用字符串的 0 索引来引用第一个字符。

字符串不能有字符串索引(就像字典一样)。所以这行不通:

 >>> mystring = 'helloworld'
>>> print mystring['stringindex']
TypeError: string indices must be integers

原文由 bluepnume 发布,翻译遵循 CC BY-SA 3.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题