python sys库递归深度_python – json树中超出了最大递归深度

def get_children(node):

for child in node['children']:

yield child

for grandchild in get_children(child):

yield grandchild

for line in f:

d = json.loads(line)

child_dic={}

for child in get_children(d):

if child not in child_dic.keys():

child_dic[child["id"]]=1

当我用他的代码来查找json树有的孩子数时,

我收到一个错误

调用Python对象时超出了最大递归深度.

请帮我一样.

最佳答案 你有一棵树的深度超过了998级:

>>> def build_nested(depth):

... d = {'children': []}

... for i in range(depth - 1):

... d['children'].append({'children': []})

... d = d['children'][0]

... return d

...

>>> try:

... len(list(get_children(build_nested(998))))

... except RuntimeError:

... print 'too deep'

...

997

>>> try:

... len(list(get_children(build_nested(999))))

... except RuntimeError:

... print 'too deep'

...

too deep

在这种情况下不要使用递归.使用堆栈:

def get_children(node):

stack = [node]

while stack:

node = stack.pop()

stack.extend(node['children'][::-1])

yield node

这个简单的方法首先遍历您的树深度,就像递归版本一样,以相同的顺序遍历.

这仅受您可以为Python提供的内存量的限制:

>>> try:

... len(list(get_children(build_nested(999))))

... except RuntimeError:

... print 'too deep'

...

998

>>> try:

... len(list(get_children(build_nested(10**6))))

... except RuntimeError:

... print 'too deep'

...

999999

然而,这无助于加载这样的物体; json库也有限制:

>>> import json

>>> json.loads('{"a":' * 100000 + '1' + '}' * 100000)

Traceback (most recent call last):

File "", line 1, in

File "/.../lib/python2.7/json/__init__.py", line 338, in loads

return _default_decoder.decode(s)

File "/.../lib/python2.7/json/decoder.py", line 366, in decode

obj, end = self.raw_decode(s, idx=_w(s, 0).end())

File "/.../lib/python2.7/json/decoder.py", line 382, in raw_decode

obj, end = self.scan_once(s, idx)

RuntimeError: maximum recursion depth exceeded while calling a Python object

您可以尝试使用sys.setrecursionlimit()提高Python递归限制,但要小心.将它设置得太高,你将使用段错误来破坏Python解释器.首先查看sys.getrecursionlimit()并将其作为起点来增加限制,直到您可以加载数据.

我不知道任何其他Python JSON库可以处理您看起来具有如此深度的JSON对象. jsonlib2只是段错误,ujson有1024个对象的硬编码深度限制,而且demjson也给你一个最大的递归深度错误.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值