Как бы вы прочитали XML-файл, используя sax, и преобразовали его в элемент lxml etree.iterparse?
Чтобы дать общее представление о проблеме, я создал инструмент приема XML, использующий lxml для подачи XML, который будет иметь размер 25–500 МБ, который требуется для приема дважды в день, но должен выполнять один время загрузки файла размером 60 - 100 ГБ.
Я решил использовать lxml, основываясь на спецификациях, согласно которым размер узла не должен превышать 4-8 ГБ, что, как я думал, позволит узлу считываться в память и очищаться после завершения.
Обзор, если код ниже
elements = etree.iterparse(
self._source, events = ('end',)
)
for event, element in elements:
finished = True
if element.tag == 'Artist-Types':
self.artist_types(element)
def artist_types(self, element):
"""
Imports artist types
:param list element: etree.Element
:returns boolean:
"""
self._log.info("Importing Artist types")
count = 0
for child in element:
failed = False
fields = self._getElementFields(child, (
('id', 'Id'),
('type_code', 'Type-Code'),
('created_date', 'Created-Date')
))
if self._type is IMPORT_INC and has_artist_type(fields['id']):
if update_artist_type(fields['id'], fields['type_code']):
count = count + 1
else:
failed = True
else:
if create_artist_type(fields['type_code'],
fields['created_date'], fields['id']):
count = count + 1
else:
failed = True
if failed:
self._log.error("Failed to import artist type %s %s" %
(fields['id'], fields['type_code'])
)
self._log.info("Imported %d Artist Types Records" % count)
self._artist_type_count = count
self._cleanup(element)
del element
Дайте мне знать, могу ли я добавить какие-либо разъяснения.