首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Python: ijson.parse(in_file)与json.load(in_file)

Python: ijson.parse(in_file)与json.load(in_file)
EN

Stack Overflow用户
提问于 2017-01-01 22:41:58
回答 1查看 3.2K关注 0票数 1

我试图在python中读取一个大型JSON文件(~ 2GB)。

下面的代码在小文件上工作得很好,但是由于第二行的MemoryError而不能在大文件上工作。

代码语言:javascript
复制
in_file = open(sys.argv[1], 'r')
posts = json.load(in_file)

我看了similar posts,几乎每个人都建议使用ijson,所以我决定试一试。

代码语言:javascript
复制
in_file = open(sys.argv[1], 'r')
posts = list(ijson.parse(in_file))

这处理了读取大文件大小的问题,但ijson.parse没有像json.load那样返回JSON对象,因此我的其余代码无法工作

TypeError:元组索引必须是整数或切片,而不是str。

如果我在使用json.load时打印出“post”,则o/p看起来像一个普通的JSON

代码语言:javascript
复制
[{"Id": "23400089", "PostTypeId": "2", "ParentId": "23113726", "CreationDate": ... etc

如果我在使用ijson.parse之后打印出“post”,那么o/p看起来就像一个散列映射。

代码语言:javascript
复制
[["", "start_array", null], ["item", "start_map", null], 
 ["item", "map_key", "Id"], ["item.Id", "string ... etc

我的问题是:我不想更改我剩下的代码,所以我想知道是否有任何方法将ijson.parse(in_file)的o/p转换回JSON对象,这样它就像我们使用json.load(in_file)一样

EN

回答 1

Stack Overflow用户

发布于 2019-09-04 08:59:08

也许这对你有用:

代码语言:javascript
复制
in_file = open(sys.argv[1], 'r')
posts = []
data = ijson.items(in_file, 'item')
for post in data:
    posts.append(post)
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/41419679

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档