當前位置: 首頁>>代碼示例>>Python>>正文


Python etree.iterparse方法代碼示例

本文整理匯總了Python中lxml.etree.iterparse方法的典型用法代碼示例。如果您正苦於以下問題:Python etree.iterparse方法的具體用法?Python etree.iterparse怎麽用?Python etree.iterparse使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在lxml.etree的用法示例。


在下文中一共展示了etree.iterparse方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: parse

# 需要導入模塊: from lxml import etree [as 別名]
# 或者: from lxml.etree import iterparse [as 別名]
def parse(fp):
    """Efficiently parses an XML file from the StackExchange data dump and
    returns a generator which yields one row at a time.
    """

    context = etree.iterparse(fp, events=('end',))

    for action, elem in context:
        if elem.tag=='row':
            # processing goes here
            assert elem.text is None, "The row wasn't empty"
            yield elem.attrib

        # cleanup
        # first empty children from current element
            # This is not absolutely necessary if you are also deleting
            # siblings, but it will allow you to free memory earlier.
        elem.clear()
        # second, delete previous siblings (records)
        while elem.getprevious() is not None:
            del elem.getparent()[0]
        # make sure you have no references to Element objects outside the loop 
開發者ID:Networks-Learning,項目名稱:stackexchange-dump-to-postgres,代碼行數:24,代碼來源:row_processor.py

示例2: _g_process_et_items

# 需要導入模塊: from lxml import etree [as 別名]
# 或者: from lxml.etree import iterparse [as 別名]
def _g_process_et_items(path, tag) -> Iterable[Tuple]:
        """
        Generator: Processes ElementTree items in a memory
        efficient way
        """

        context: etree.ElementTree = etree.iterparse(
            path, events=('end',), tag=tag
        )

        for event, elem in context:
            yield event, elem

            # delete content of node once we're done processing
            # it. If we don't then it would stay in memory
            elem.clear() 
開發者ID:Wikidata,項目名稱:soweego,代碼行數:18,代碼來源:discogs_dump_extractor.py

示例3: get_parser

# 需要導入模塊: from lxml import etree [as 別名]
# 或者: from lxml.etree import iterparse [as 別名]
def get_parser(filename):
    ns_token        = '{http://www.mediawiki.org/xml/export-0.10/}ns'
    title_token     = '{http://www.mediawiki.org/xml/export-0.10/}title'
    revision_token  = '{http://www.mediawiki.org/xml/export-0.10/}revision'
    text_token      = '{http://www.mediawiki.org/xml/export-0.10/}text'

    with bz2.BZ2File(filename, 'r+b') as bz2_file:
        for event, element in etree.iterparse(bz2_file, events=('end',)):
            if element.tag.endswith('page'):
                namespace_tag = element.find(ns_token)

                if namespace_tag.text == '0':
                    title_tag = element.find(title_token)
                    text_tag = element.find(revision_token).find(text_token)
                    yield title_tag.text, text_tag.text

                element.clear() 
開發者ID:marklit,項目名稱:airline-passenger-counts,代碼行數:19,代碼來源:app.py

示例4: parse

# 需要導入模塊: from lxml import etree [as 別名]
# 或者: from lxml.etree import iterparse [as 別名]
def parse(self, xml):
        result = {
            'type': None,
            'taskId': None,
            'maxSeverity': None,
            'objects': [],
            'problems': [],
        }

        events = ("start", "end")

        context = etree.iterparse(six.BytesIO(xml),
                                  events=events)
        for action, elem in context:
            self.tag = self._remove_ns(elem.tag)

            func = self._get_func(action, self.tag)
            if func in vars(XMLAPIParser):
                if action == 'start':
                    eval('self.' + func)(elem, result)
                elif action == 'end':
                    eval('self.' + func)()

        return result 
開發者ID:openstack,項目名稱:manila,代碼行數:26,代碼來源:xml_api_parser.py

示例5: iso_info

# 需要導入模塊: from lxml import etree [as 別名]
# 或者: from lxml.etree import iterparse [as 別名]
def iso_info(self, iso):
        result = dict(
            product=None,
            version=None,
            build=None
        )

        iso = isoparser.parse(iso)
        content = self._find_iso_content(iso)
        content = io.BytesIO(content)

        context = etree.iterparse(content)
        for action, elem in context:
            if elem.text:
                text = elem.text

            if elem.tag == 'productName':
                result['product'] = text
            elif elem.tag == 'version':
                result['version'] = text
            elif elem.tag == 'buildNumber':
                result['build'] = text

        return result 
開發者ID:mcgonagle,項目名稱:ansible_f5,代碼行數:26,代碼來源:bigip_software.py

示例6: init_etree

# 需要導入模塊: from lxml import etree [as 別名]
# 或者: from lxml.etree import iterparse [as 別名]
def init_etree(self):
        """
        Creates the ``lxml.etree.iterparse`` object.
        This method should not be called directly,
        ``BioPaxReader.process()`` calls it.
        """
        try:

            self.bp = etree.iterparse(self._biopax, events=('start', 'end'))
            _, self.root = next(self.bp)

        except etree.XMLSyntaxError:

            self.bp = None

        self.used_elements = [] 
開發者ID:saezlab,項目名稱:pypath,代碼行數:18,代碼來源:pyreact.py

示例7: ParseXmlResponse

# 需要導入模塊: from lxml import etree [as 別名]
# 或者: from lxml.etree import iterparse [as 別名]
def ParseXmlResponse(self, xml, localOnly=False, subscriptionIds=[]):
        # https://gist.github.com/karlcow/3258330
        xml = bytes(bytearray(xml, encoding='utf-8'))
        context = etree.iterparse(BytesIO(xml),
                                  events=('end',), tag='imdata')
        mos = []
        event, root = next(context)
        sIds = root.get('subscriptionId', '')
        if sIds:
            subscriptionIds.extend([str(x) for x in sIds.split(',')])
        for element in root.iterchildren():
            if 'dn' not in element.attrib:
                raise MoError('Property `dn` not found in element {}'.format(
                    _elementToString(element)))
            if element.tag == 'moCount':
                mo = self.moCount()
            else:
                mo = self.FromDn(element.attrib['dn'])
            mo._fromXmlElement(element, localOnly=localOnly)
            element.clear()
            mos.append(mo)
        return mos 
開發者ID:datacenter,項目名稱:pyaci,代碼行數:24,代碼來源:core.py

示例8: lxml_trace

# 需要導入模塊: from lxml import etree [as 別名]
# 或者: from lxml.etree import iterparse [as 別名]
def lxml_trace(data, html=True, **kwargs):
    """Print out the lxml events that occur during parsing.

    This lets you see how lxml parses a document when no Beautiful
    Soup code is running.
    """
    from lxml import etree
    for event, element in etree.iterparse(StringIO(data), html=html, **kwargs):
        print("%s, %4s, %s" % (event, element.tag, element.text)) 
開發者ID:MarcelloLins,項目名稱:ServerlessCrawler-VancouverRealState,代碼行數:11,代碼來源:diagnose.py

示例9: build_corpus

# 需要導入模塊: from lxml import etree [as 別名]
# 或者: from lxml.etree import iterparse [as 別名]
def build_corpus():
    global lcode, max_corpus_size, fname
    with codecs.open("data/{}.txt".format(lcode), 'w', 'utf-8') as fout:
        i = 1
        j = 1
        ns = "{http://www.mediawiki.org/xml/export-0.10/}" # namespace
        for _, elem in ET.iterparse("data/{}".format(fname), tag=ns+"text"):
            running_text = elem.text
            try:
                running_text = clean_text(running_text)
                sents = sentence_segment(running_text)
                for sent in sents:
                    if sent is not None:
                        words = word_segment(sent)
                        if len(words) > 10:
                            if lcode in ['ja']:
                                fout.write(" ".join(words).decode('utf8') + "\n")
                            else:
                                fout.write(" ".join(words) + "\n")
                                
            except:
                continue # it's okay as we have a pretty big corpus!
            elem.clear() # We need to save memory!
            if i % 1000 == 0: 
                print i,
                fsize = os.path.getsize("data/{}.txt".format(lcode))
                if fsize > max_corpus_size:
                    break
            i += 1 
開發者ID:Kyubyong,項目名稱:wordvectors,代碼行數:31,代碼來源:build_corpus.py

示例10: _parse_and_remove

# 需要導入模塊: from lxml import etree [as 別名]
# 或者: from lxml.etree import iterparse [as 別名]
def _parse_and_remove(self, f, path):
        """
        snippet from python cookbook, for parsing large xml file
        """
        path_parts = path.split('/')
        doc = iterparse(f, ('start', 'end'), recover=False, encoding='utf-8', huge_tree=True)
        # Skip the root element
        next(doc)
        tag_stack = []
        elem_stack = []
        for event, elem in doc:
            if event == 'start':
                tag_stack.append(elem.tag)
                elem_stack.append(elem)
            elif event == 'end':
                if tag_stack == path_parts:
                    yield elem
                    elem_stack[-2].remove(elem)
                if tag_stack == ['database', 'table_structure']:  # dirty hack for getting the tables structure
                    self._parse_table_structure(elem)
                    elem_stack[-2].remove(elem)
                try:
                    tag_stack.pop()
                    elem_stack.pop()
                except IndexError:
                    pass 
開發者ID:zhongbiaodev,項目名稱:py-mysql-elasticsearch-sync,代碼行數:28,代碼來源:__init__.py

示例11: _parse_and_remove

# 需要導入模塊: from lxml import etree [as 別名]
# 或者: from lxml.etree import iterparse [as 別名]
def _parse_and_remove(self, f, path):
        """
        snippet from python cookbook, for parsing large xml file
        """
        path_parts = path.split('/')
        doc = iterparse(f, ('start', 'end'), recover=False, encoding='utf-8', huge_tree=True)
        # Skip the root element
        next(doc)
        tag_stack = []
        elem_stack = []
        for event, elem in doc:
            if event == 'start':
                if elem.tag == 'table_data':
                    self.current_table = elem.attrib['name']
                tag_stack.append(elem.tag)
                elem_stack.append(elem)
            elif event == 'end':
                if tag_stack == ['database', 'table_data']:
                    self.current_table = None
                if tag_stack == path_parts:
                    yield elem
                    elem_stack[-2].remove(elem)
                if tag_stack == ['database', 'table_structure']:
                # dirty hack for getting the tables structure
                    self._parse_table_structure(elem)
                    elem_stack[-2].remove(elem)
                try:
                    tag_stack.pop()
                    elem_stack.pop()
                except IndexError:
                    pass 
開發者ID:zhongbiaodev,項目名稱:py-mysql-elasticsearch-sync,代碼行數:33,代碼來源:__init__.py

示例12: get_tag_attributes

# 需要導入模塊: from lxml import etree [as 別名]
# 或者: from lxml.etree import iterparse [as 別名]
def get_tag_attributes(source, tag_name):
    '''Iteratively parse XML stream in ``source`` until encountering ``tag_name``
    at which point parsing terminates and return the attributes of the matched
    tag.

    Parameters
    ----------
    source: file-like
        A file-like object over an XML document
    tag_name: str
        The name of the XML tag to parse until

    Returns
    -------
    dict
    '''
    g = etree.iterparse(source, ('start', 'end'))
    for event, tag in g:
        if event == 'start':
            if xml._local_name(tag) == tag_name:
                return tag.attrib
            else:
                continue
        else:
            tag.clear()
    return None 
開發者ID:mobiusklein,項目名稱:ms_deisotope,代碼行數:28,代碼來源:xml_reader.py

示例13: iterparse_until

# 需要導入模塊: from lxml import etree [as 別名]
# 或者: from lxml.etree import iterparse [as 別名]
def iterparse_until(source, target_name, quit_name):
    '''Iteratively parse XML stream in ``source``, yielding XML elements
    matching ``target_name``. If at any point a tag matching ``quit_name``
    is encountered, stop parsing.

    Parameters
    ----------
    source: file-like
        A file-like object over an XML document
    tag_name: str
        The name of the XML tag to parse until
    quit_name: str
        The name to stop parsing at.

    Yields
    ------
    lxml.etree.Element
    '''
    g = etree.iterparse(source, ('start', 'end'))
    for event, tag in g:
        if event == 'start':
            if xml._local_name(tag) == quit_name:
                break
            else:
                if xml._local_name(tag) == target_name:
                    yield tag
                else:
                    tag.clear() 
開發者ID:mobiusklein,項目名稱:ms_deisotope,代碼行數:30,代碼來源:xml_reader.py

示例14: iterparse

# 需要導入模塊: from lxml import etree [as 別名]
# 或者: from lxml.etree import iterparse [as 別名]
def iterparse(self):
        """
        Use lxml.etree.iterparse to parse data.xml.
        """
        file_name = os.path.join(self.data_dir, "data.xml")
        with open(file_name, "r") as f:
            etree.iterparse(file_name, events=("start", "end")) 
開發者ID:recipy,項目名稱:recipy,代碼行數:9,代碼來源:run_lxml.py

示例15: lxml_trace

# 需要導入模塊: from lxml import etree [as 別名]
# 或者: from lxml.etree import iterparse [as 別名]
def lxml_trace(data, html=True, **kwargs):
    """Print out the lxml events that occur during parsing.

    This lets you see how lxml parses a document when no Beautiful
    Soup code is running.
    """
    from lxml import etree
    for event, element in etree.iterparse(StringIO(data), html=html, **kwargs):
        print(("%s, %4s, %s" % (event, element.tag, element.text))) 
開發者ID:the-ethan-hunt,項目名稱:B.E.N.J.I.,代碼行數:11,代碼來源:diagnose.py


注:本文中的lxml.etree.iterparse方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。