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


Python etree.cleanup_namespaces方法代碼示例

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


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

示例1: test_add_netconf_attr_prefix

# 需要導入模塊: from lxml import etree [as 別名]
# 或者: from lxml.etree import cleanup_namespaces [as 別名]
def test_add_netconf_attr_prefix(self):
        """Handling of netconf attributes with and without prefix."""
        elem = self.rpcbld.netconf_element('rpc')
        self.rpcbld.add_netconf_attr(elem, 'message-id', 101)
        et.cleanup_namespaces(
            elem, keep_ns_prefixes=sorted(self.rpcbld.keep_prefixes))

        self.assertEqual("""\
<nc:rpc xmlns:nc="urn:ietf:params:xml:ns:netconf:base:1.0" \
nc:message-id="101"/>
""", et.tostring(elem, encoding='unicode', pretty_print=True))

        elem = self.rpcbld_minimal.netconf_element('rpc')
        self.rpcbld_minimal.add_netconf_attr(elem, 'message-id', 101)
        et.cleanup_namespaces(
            elem, keep_ns_prefixes=sorted(self.rpcbld_minimal.keep_prefixes))

        self.assertEqual("""\
<rpc xmlns="urn:ietf:params:xml:ns:netconf:base:1.0" message-id="101"/>
""", et.tostring(elem, encoding='unicode', pretty_print=True)) 
開發者ID:CiscoTestAutomation,項目名稱:genielibs,代碼行數:22,代碼來源:test_rpcbuilder.py

示例2: format

# 需要導入模塊: from lxml import etree [as 別名]
# 或者: from lxml.etree import cleanup_namespaces [as 別名]
def format(self, diff, orig_tree, differ=None):
        # Make a new tree, both because we want to add the diff namespace
        # and also because we don't want to modify the original tree.
        result = deepcopy(orig_tree)
        if isinstance(result, etree._ElementTree):
            root = result.getroot()
        else:
            root = result

        etree.register_namespace(DIFF_PREFIX, DIFF_NS)

        for action in diff:
            self.handle_action(action, root)

        self.finalize(root)

        etree.cleanup_namespaces(result, top_nsmap={DIFF_PREFIX: DIFF_NS})
        return self.render(result) 
開發者ID:Shoobx,項目名稱:xmldiff,代碼行數:20,代碼來源:formatting.py

示例3: serialize

# 需要導入模塊: from lxml import etree [as 別名]
# 或者: from lxml.etree import cleanup_namespaces [as 別名]
def serialize(self, sink: Union[IO, str], cas: Cas, pretty_print=True):
        xmi_attrs = {"{http://www.omg.org/XMI}version": "2.0"}

        root = etree.Element(etree.QName(self._nsmap["xmi"], "XMI"), nsmap=self._nsmap, **xmi_attrs)

        self._serialize_cas_null(root)

        # Find all fs, even the ones that are not directly added to a sofa
        for fs in sorted(cas._find_all_fs(), key=lambda a: a.xmiID):
            self._serialize_feature_structure(cas, root, fs)

        for sofa in cas.sofas:
            self._serialize_sofa(root, sofa)

        for view in cas.views:
            self._serialize_view(root, view)

        doc = etree.ElementTree(root)
        etree.cleanup_namespaces(doc, top_nsmap=self._nsmap)

        doc.write(sink, xml_declaration=True, pretty_print=pretty_print) 
開發者ID:dkpro,項目名稱:dkpro-cassis,代碼行數:23,代碼來源:xmi.py

示例4: to_string

# 需要導入模塊: from lxml import etree [as 別名]
# 或者: from lxml.etree import cleanup_namespaces [as 別名]
def to_string(xml, **kwargs):
        """
        Serialize an element to an encoded string representation of its XML tree.
        :param xml: The root node
        :type xml: str|bytes|xml.dom.minidom.Document|etree.Element
        :returns: string representation of xml
        :rtype: string
        """

        if isinstance(xml, OneLogin_Saml2_XML._text_class):
            return xml

        if isinstance(xml, OneLogin_Saml2_XML._element_class):
            OneLogin_Saml2_XML.cleanup_namespaces(xml)
            return OneLogin_Saml2_XML._unparse_etree(xml, **kwargs)

        raise ValueError("unsupported type %r" % type(xml)) 
開發者ID:onelogin,項目名稱:python3-saml,代碼行數:19,代碼來源:xml_utils.py

示例5: cleanup_namespaces

# 需要導入模塊: from lxml import etree [as 別名]
# 或者: from lxml.etree import cleanup_namespaces [as 別名]
def cleanup_namespaces(tree_or_element, top_nsmap=None, keep_ns_prefixes=None):
        """
        Keeps the xmlns:xs namespace intact when etree.cleanup_namespaces is invoked.
        :param tree_or_element: An XML tree or element
        :type tree_or_element: etree.Element
        :param top_nsmap: A mapping from namespace prefixes to namespace URIs
        :type top_nsmap: dict
        :param keep_ns_prefixes: List of prefixes that should not be removed as part of the cleanup
        :type keep_ns_prefixes: list
        :returns: An XML tree or element
        :rtype: etree.Element
        """
        all_prefixes_to_keep = [
            OneLogin_Saml2_Constants.NS_PREFIX_XS,
            OneLogin_Saml2_Constants.NS_PREFIX_XSI,
            OneLogin_Saml2_Constants.NS_PREFIX_XSD
        ]

        if keep_ns_prefixes:
            all_prefixes_to_keep = list(set(all_prefixes_to_keep.extend(keep_ns_prefixes)))

        return etree.cleanup_namespaces(tree_or_element, keep_ns_prefixes=all_prefixes_to_keep) 
開發者ID:onelogin,項目名稱:python3-saml,代碼行數:24,代碼來源:xml_utils.py

示例6: main

# 需要導入模塊: from lxml import etree [as 別名]
# 或者: from lxml.etree import cleanup_namespaces [as 別名]
def main():
    data = sys.stdin.readlines()
    payload = data[0]
    payload_dict = json.loads(payload)

    if "response" in payload_dict and "body" in payload_dict["response"]:
        body = payload_dict["response"]["body"]
        try:
            root = objectify.fromstring(str(body))
            ns = "{http://ws.cdyne.com/}"
            logging.debug("transforming")

            ipe = ns + "ResolveIPResponse"
            ipt = ns + "ResolveIPResult"

            root.Body[ipe][ipt].City = "New York"

            objectify.deannotate(root.Body[ipe][ipt].City)
            etree.cleanup_namespaces(root.Body[ipe][ipt].City)

            payload_dict["response"]["body"] = etree.tostring(root)

            logging.debug(etree.tostring(root))

        except Exception:
            pass

    print(json.dumps(payload_dict)) 
開發者ID:SpectoLabs,項目名稱:hoverpy,代碼行數:30,代碼來源:modify_payload.py

示例7: remove_namespaces

# 需要導入模塊: from lxml import etree [as 別名]
# 或者: from lxml.etree import cleanup_namespaces [as 別名]
def remove_namespaces(self):
        """
        Remove all namespaces, allowing to traverse the document using
        namespace-less xpaths. See :ref:`removing-namespaces`.
        """
        for el in self.root.iter('*'):
            if el.tag.startswith('{'):
                el.tag = el.tag.split('}', 1)[1]
            # loop on element attributes also
            for an in el.attrib.keys():
                if an.startswith('{'):
                    el.attrib[an.split('}', 1)[1]] = el.attrib.pop(an)
        # remove namespace declarations
        etree.cleanup_namespaces(self.root) 
開發者ID:wistbean,項目名稱:learn_python3_spider,代碼行數:16,代碼來源:selector.py

示例8: remove_namespaces

# 需要導入模塊: from lxml import etree [as 別名]
# 或者: from lxml.etree import cleanup_namespaces [as 別名]
def remove_namespaces(self):
        """
        Remove all namespaces, allowing to traverse the document using
        namespace-less xpaths. See :ref:`removing-namespaces`.
        """
        for el in self.root.iter('*'):
            if el.tag.startswith('{'):
                el.tag = el.tag.split('}', 1)[1]
            # loop on element attributes also
            for an in el.attrib.keys():
                if an.startswith('{'):
                    el.attrib[an.split('}', 1)[1]] = el.attrib.pop(an)
            # remove namespace declarations
            etree.cleanup_namespaces(self.root) 
開發者ID:MrH0wl,項目名稱:Cloudmare,代碼行數:16,代碼來源:selector.py

示例9: _save_script

# 需要導入模塊: from lxml import etree [as 別名]
# 或者: from lxml.etree import cleanup_namespaces [as 別名]
def _save_script(self):
        # objectify.deannotate(self.dragon)
        etree.cleanup_namespaces(self.dragon)
        self.drs_name = 'Dragon_script.drs'
        with open(os.path.join(self.output_directory, self.drs_name), 'w') as outfile:
            outfile.write(etree.tostring(self.dragon, pretty_print=True).decode()) 
開發者ID:hachmannlab,項目名稱:chemml,代碼行數:8,代碼來源:Dragon.py

示例10: printout

# 需要導入模塊: from lxml import etree [as 別名]
# 或者: from lxml.etree import cleanup_namespaces [as 別名]
def printout(self):
        objectify.deannotate(self.dragon)
        etree.cleanup_namespaces(self.dragon)
        print(objectify.dump(self.dragon)) 
開發者ID:hachmannlab,項目名稱:chemml,代碼行數:6,代碼來源:Dragon.py


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