当尝试将 JSON 文件中的数据转换为可理解的 CSV 格式时,您可能会遇到“TypeError:字符串索引必须是整数”错误。当像字典一样访问字符串的字段时,会出现此错误。让我们探讨一下解决方案。
要理解该错误,需要注意的是,Python 中的字符串无法像字典一样进行索引。在字典中,键可以作为字符串访问,例如字典[“key”]。相反,访问字符串的字段必须使用整数索引来完成,如下例所示:
mystring = "helloworld" print(mystring[0]) # Outputs 'h', as '0' refers to the first character
在您的代码中,您正在尝试访问字段item 变量的字符串类型:
csv_file.writerow([item["gravatar_id"], item["position"], item["number"]])
要解决此问题,请在访问 item 变量之前将其转换为字典fields:
csv_file.writerow([item.get("gravatar_id"), item.get("position"), item.get("number")])
或者,您可以使用json模块的loads()函数将项目字符串直接转换为字典:
item_dict = json.loads(item) csv_file.writerow([item_dict["gravatar_id"], item_dict["position"], item_dict["number")])
这些修改将确保您访问字段使用整数索引,解决“TypeError:字符串索引必须是整数”错误。
以上是解析 JSON 数据时如何解决'TypeError:字符串索引必须是整数”?的详细内容。更多信息请关注PHP中文网其他相关文章!