5

我正在解析一个 700mb 的文件,我有以下代码在我的测试文件上运行良好,没有行 context.iter(context) 和 event,elem = context.next()。

form xml.etree import cElementTree as ET
source = ("AAT.xml")
context = iter(context)
event, root = context.next()
for event, elem in context:
         if event == event("end"):
             some processing...
             elem.clear()
         root.clear()

但是,当我继续 iterparse 700mb 文件时,它仍然崩溃。读过:

在清除()树时使用 ElementTree.iterparse() 是否应该增加内存使用量?

我相信这是因为我需要清除根目录,但是按照我在上面合并的一些教程后,我不断收到错误消息:

line 9, in <module>
event, root = context.next()
AttributeError: 'iterparse' object has no attribute 'next'

我对 Python 还是很陌生,我无法弄清楚为什么会发生这种情况,据我所知,我与示例一致。

4

1 回答 1

15

假设您使用的是 Python3,迭代器语法next(context)context.next()

于 2015-02-16T13:33:56.297 回答