gpt4 book ai didi

python - 在 Python 中,如何引用包含连字符的 XML 标记

转载 作者:数据小太阳 更新时间:2023-10-29 01:51:18 29 4
gpt4 key购买 nike

我正在尝试使用 BeautifulSoup 来解析 XML 文件。其中一个元素中有一个连字符:distribution-code

我如何访问它?我试过:

soup.distribution-code
soup."distribution-code" (tried single quotes too)
soup.[distribution-code]

但这些都不起作用。

最佳答案

您可以使用常规 Python 语法通过属性引用访问非连字符元素,即 obj.name,但是,- 不是使用该语法时的有效字符(Python 将其视为“减号”运算符),因此您无法通过该方法访问此类元素。

相反,使用 soup.find()soup.find_all():

>>> from bs4 import BeautifulSoup
>>> soup = BeautifulSoup('<thing><id>1234</id><distribution-code>555444333</distribution-code></thing>')
>>> soup.thing
<thing><id>1234</id><distribution-code>555444333</distribution-code></thing>
>>> soup.id
<id>1234</id>
>>> soup.distribution-code
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
NameError: name 'code' is not defined
>>> soup.find('distribution-code')
<distribution-code>555444333</distribution-code>

或者,正如 chepner's comment 中指出的那样,您可以使用 getattr()setattr() 获取和设置包含连字符的属性。我认为 soup.find() 是访问这些元素的更常用方法。

关于python - 在 Python 中,如何引用包含连字符的 XML 标记,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33250363/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com