Путаница корневых элементов с помощью ElementTree - PullRequest
0 голосов
/ 14 января 2019

Я использую ElementTree в Python 3.5.1. Я хочу проанализировать XML-файл, например:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <name>A name</name>
    <groupId>a.group</groupId>
    <artifactId>anArtifact</artifactId>
    <version>1.0</version>
    <packaging>pom</packaging>
    <properties>
        <dependency-version>10.0</dependency-version>
        <another-dependency-version>11.0</another-dependency-version>
    </properties>
</project>

И получить значение тега зависимость-версия . Я начал пытаться получить свойства , используя этот код:

mydoc = ElementTree.parse(sources + "pom.xml")
root = mydoc.getroot()
for element in root.findall('properties'):
    print(element)

Проблема в том, что у меня нет ничего, кроме корневого тега project и его атрибутов.

>>> root.tag
'{http://maven.apache.org/POM/4.0.0}project'
>>> root.text
'\n    '
>>> root.attrib
{'{http://www.w3.org/2001/XMLSchema-instance}schemaLocation': 'http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd'}

Я пытался также с mydoc напрямую:

>>> root.findall('project')
[]
>>> mydoc.findall('./properties')
[]
>>> mydoc.findall('./project/properties') 
[]

Я понял, что getroot () даст мне тег проекта, и оттуда я смогу начать работать, но, похоже, я что-то не так понял.

EDIT

Я последовал предложенному решению и получил:

>>> ns
{'sm': 'http://maven.apache.org/POM/4.0.0'}
>>> mydoc.findall('.//sm:properties', ns)
[<Element '{http://maven.apache.org/POM/4.0.0}properties' at 0x0325AA80>]
>>> root.findall('.//sm:properties', ns)
[<Element '{http://maven.apache.org/POM/4.0.0}properties' at 0x0325AA80>]
>>> mydoc.findall('.//sm:properties/dependency-version', ns)
[]

Кажется, сейчас что-то находит, но не два элемента тега properties

1 Ответ

0 голосов
/ 16 января 2019

В конце я получил представление от: модуля Python ElementTree: как игнорировать пространство имен XML-файлов для поиска соответствующего элемента при использовании методов «find», «findall» Что, в основном, избавляет от пространств имен.

import re
import xml.etree.ElementTree as ElementTree

filestring = open("C:/temp/test.xml", "r").read()
xmlwithoutns = re.sub('<project[^>]+', '<project>', filestring, count=1)
tree = ElementTree.fromstring(xmlwithoutns)
value = tree.findall("properties/dependency-version")[0].text
...