python etree创建xml_python-如何使用xml.etree.Element编写XML声明

python-如何使用xml.etree.Element编写XML声明

我正在使用ElementTree在Python中生成XML文档,但是ElementTree函数在转换为纯文本时不包含XML声明。

from xml.etree.ElementTree import Element, tostring

document = Element('outer')

node = SubElement(document, 'inner')

node.NewValue = 1

print tostring(document) # Outputs ""

我需要包含以下XML声明的字符串:

但是,似乎没有任何记录的方式来执行此操作。

在ElementTree中是否存在用于呈现XML声明的适当方法?

9个解决方案

85 votes

我很惊讶地发现ElementTree.tostring()似乎没有办法。但是,您可以使用ElementTree.ElementTree.write()将XML文档写入伪文件:

from io import BytesIO

from xml.etree import ElementTree as ET

document = ET.Element('outer')

node = ET.SubElement(document, 'inner')

et = ET.ElementTree(document)

f = BytesIO()

et.write(f, encoding='utf-8', xml_declaration=True)

print(f.getvalue()) # your XML file, encoded as UTF-8

看到这个问题。 即使那样,我认为如果不自己编写,就无法获得“独立”属性。

wrgrs answered 2020-01-23T12:28:44Z

22 votes

我将使用lxml(请参阅[http://lxml.de/api.html]。)

那么你就可以:

from lxml import etree

document = etree.Element('outer')

node = etree.SubElement(document, 'inner')

print(etree.tostring(document, xml_declaration=True))

glormph answered 2020-01-23T12:29:08Z

14 votes

如果包含encoding='utf8',您将获得XML标头:

xml.etree.ElementTree.tostring使用encoding ='utf8'编写XML编码声明

示例Python代码(适用于Python 2和3):

import xml.etree.ElementTree as ElementTree

tree = ElementTree.ElementTree(

ElementTree.fromstring('123')

)

root = tree.getroot()

print('without:')

print(ElementTree.tostring(root, method='xml'))

print('')

print('with:')

print(ElementTree.tostring(root, encoding='utf8', method='xml'))

Python 2输出:

$ python2 example.py

without:

123

with:

123

使用Python 3时,您会注意到b前缀,该前缀指示返回字节文字(就像Python 2一样):

$ python3 example.py

without:

b'123'

with:

b"<?xml version='1.0' encoding='utf8'?>\n123"

Alexander O'Mara answered 2020-01-23T12:29:46Z

3 votes

我最近遇到此问题,在对代码进行了一些挖掘之后,我发现以下代码片段是函数的定义encoding

def write(self, file, encoding="us-ascii"):

assert self._root is not None

if not hasattr(file, "write"):

file = open(file, "wb")

if not encoding:

encoding = "us-ascii"

elif encoding != "utf-8" and encoding != "us-ascii":

file.write("<?xml version='1.0' encoding='%s'?>\n" %

encoding)

self._write(file, self._root, encoding, {})

因此答案是,如果需要将XML标头写入文件,请设置utf-8或2715306863817655655以外的encoding参数。 UTF-8

alijandro answered 2020-01-23T12:30:10Z

2 votes

包含ElementTree包用法的最小工作示例:

import xml.etree.ElementTree as ET

document = ET.Element('outer')

node = ET.SubElement(document, 'inner')

node.text = '1'

res = ET.tostring(document, encoding='utf8', method='xml').decode()

print(res)

输出为:

1

Andriy answered 2020-01-23T12:30:34Z

0 votes

我会使用ET:

try:

from lxml import etree

print("running with lxml.etree")

except ImportError:

try:

# Python 2.5

import xml.etree.cElementTree as etree

print("running with cElementTree on Python 2.5+")

except ImportError:

try:

# Python 2.5

import xml.etree.ElementTree as etree

print("running with ElementTree on Python 2.5+")

except ImportError:

try:

# normal cElementTree install

import cElementTree as etree

print("running with cElementTree")

except ImportError:

try:

# normal ElementTree install

import elementtree.ElementTree as etree

print("running with ElementTree")

except ImportError:

print("Failed to import ElementTree from any known place")

document = etree.Element('outer')

node = etree.SubElement(document, 'inner')

print(etree.tostring(document, encoding='UTF-8', xml_declaration=True))

Alessandro answered 2020-01-23T12:30:54Z

0 votes

如果您只想打印,则此方法有效。 尝试将其发送到文件时出现错误...

import xml.dom.minidom as minidom

import xml.etree.ElementTree as ET

from xml.etree.ElementTree import Element, SubElement, Comment, tostring

def prettify(elem):

rough_string = ET.tostring(elem, 'utf-8')

reparsed = minidom.parseString(rough_string)

return reparsed.toprettyxml(indent=" ")

Rebecca Fallon answered 2020-01-23T12:31:14Z

0 votes

在声明中包括“独立”

我在文档中找不到添加standalone自变量的任何替代方法,因此我改编了ET.tosting函数以将其作为自变量。

from xml.etree import ElementTree as ET

# Sample

document = ET.Element('outer')

node = ET.SubElement(document, 'inner')

et = ET.ElementTree(document)

# Function that you need

def tostring(element, declaration, encoding=None, method=None,):

class dummy:

pass

data = []

data.append(declaration+"\n")

file = dummy()

file.write = data.append

ET.ElementTree(element).write(file, encoding, method=method)

return "".join(data)

# Working example

xdec = """<?xml version="1.0" encoding="UTF-8" standalone="no" ?>"""

xml = tostring(document, encoding='utf-8', declaration=xdec)

G M answered 2020-01-23T12:31:39Z

0 votes

另一个非常简单的选项是将所需的标头连接到xml的字符串中,如下所示:

xml = (bytes('<?xml version="1.0" encoding="UTF-8"?>\n', encoding='utf-8') + ET.tostring(root))

xml = xml.decode('utf-8')

with open('invoice.xml', 'w+') as f:

f.write(xml)

Novak answered 2020-01-23T12:31:59Z

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Python中的xml.etree.ElementTree是一个用于解析和操作XML文档的模块。它提供了一种简单的方式来读取和写入XML文件,并且可以轻松地遍历XML文档的元素和属性。使用xml.etree.ElementTree模块,可以将XML文档转换为Python对象,然后对其进行操作和处理。 ### 回答2: Python xml.etree.elementtree 是一个 Python 模块,用于解析 XML 文档并创建 XML 元素树。这个模块提供了一种简单且高效的方式来处理 XML 数据,可以帮助开发者轻松地构建 Python 对象/字典和 XML 文档之间的映射。 使用 xml.etree.ElementTree,可以将 XML 文档转换为元素对象树,然后使用元素对象进行文档处理。使用这个模块可以很容易地将 XML 数据解析和转换为 Python 中的数据类型,例如列表、字典和字符串等。同时,ElementTree 还支持 XPath 表达式(XPath 是一种用于选取 XML 文档中数据的语言)。 ElementTree 将一个 XML 文档解析成一个通用的元素树结构,将每个元素作为 Python 对象中的一个元素。在几乎所有的XML处理扩展中,ElementTree都是标准的API。其重要的特点包括: 1. 简单易用的API,支持解析和生成XML; 2. 支持遍历解析XML文档; 3. 支持XPath定位; 4. 遵守XML标准,并且能够正确处理XML文档中的编码格式、属性和命名空间等细节; 5. 兼容Python3与Python2. 在Python应用领域中,XML是一种常见格式,如SOAP和RESTful Web Services、HTML、配置文件等等。使用 ElementTree,可以方便地处理这些数据供应用完成数据处理,构建XML数据请求和响应等。总之,Python xml.etree.elementtree 是一个基于 XML 的开发框架,可用于快速,可靠地构建和解析 XML 文档。 ### 回答3: Python 中的 xml.etree.elementtree 是一个用于操作 XML 数据的库。ElementTree 是 Element 的树形结构,允许对其进行操作并将其转换为 XML 文件或字符串。它被广泛应用于 Web 开发和数据处理,例如在面向 XML 数据的 Web 应用程序和配置文件中。 ElementTree 提供了一个对 XML 元素进行递归访问的 API。通过向 XML 解析器提供 XML 文件路径或 URL,ElementTree 可以读取 XML 文件并将其转换为一个 element 对象。通过 element 对象,我们可以获得元素的文本内容、属性、子元素、标签等信息。 ElementTree 还提供了一些实用函数,帮助我们轻松地操作 XML 数据。例如,我们可以使用 find() 和 findall() 函数搜索 Element 中的子元素,并使用 set() 函数设置元素的属性、text 属性来获取或设置元素的文本内容。 在使用 xml.etree.elementtree 进行 XML 数据处理时,我们还可以使用 lxml、BeautifulSoup 和 html5lib 等库,以便更方便地解析、操作和处理 XML 数据。 总之,Python 中的 xml.etree.elementtree 提供了强大的 XML 数据处理功能,使得我们可以轻松地访问、解析和操作 XML 数据。无论是 Web 应用程序还是常规数据处理,ElementTree 都是一个值得信赖和广泛运用的库。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值