【发布时间】:2019-04-24 12:44:20
【问题描述】:
我正在尝试从 xml 文件中提取 X、Y、Z 的列表。 xml的一部分是:
<Data>
<TargetPosition X="57.23471787820652" Y="-26.04271457691532"
Z="9.988092935592704" Valid="1"/> #PosLang
<StartPosition X="0" Y="0" Z="0" Valid="0"/>
</Data>
</Object>
<Object Type="{aa99a9ec-4b85-442e-b914-de3579656eb5}">
<ParentTObject Valid="1">
<Translation X="0" Y="0" Z="0"/>
<Rotation W="1" X="0" Y="0" Z="0"/>
</ParentTObject>
<Data>
<TargetPosition X="58.81901290773406" Y="-20.09883392050945"
Z="16.53197054898237" Valid="1"/> #NegLang
<StartPosition X="0" Y="0" Z="0" Valid="0"/>
</Data>
</Object>
我需要从具有 #PosLang 的文件中的所有 TargetPosition 中提取 X、Y、Z 评论
def targets(path='some.xml'):
try:
e = ET.parse(path).getroot()
except FileNotFoundError:
return list()
Position = namedtuple('float', ['x', 'y', 'z'])
for position in e.iter('TargetPosition'):
yield Position(
x=float(position.get('X')),
y=float(position.get('Y')),
z=float(position.get('Z'))
)
在 y 代码中,我提取所有 TargetPosition 的 X、Y、Z,但我只需要具有#PosLang 注释的代码
【问题讨论】:
-
不要混淆使用
#和 XML cmets 的 Python cmets。