Я пытаюсь преобразовать XML-файлы в json-файл в стиле кокоса.
Вот как выглядит мой XML-файл
<Annotations MicronsPerPixel="0.466667">
<Annotation Id="1" Name="" ReadOnly="0" NameReadOnly="0" LineColorReadOnly="0" Incremental="0" Type="4" LineColor="65280" Visible="1" Selected="1" MarkupImagePath="" MacroName="">
<Attributes/>
<Regions>
<RegionAttributeHeaders>
<AttributeHeader Id="9999" Name="Region" ColumnWidth="-1"/>
<AttributeHeader Id="9997" Name="Length" ColumnWidth="-1"/>
<AttributeHeader Id="9996" Name="Area" ColumnWidth="-1"/>
<AttributeHeader Id="9998" Name="Text" ColumnWidth="-1"/>
<AttributeHeader Id="1" Name="Description" ColumnWidth="-1"/>
</RegionAttributeHeaders>
<Region Id="1" Type="0" Zoom="0.500000" Selected="0" ImageLocation="" ImageFocus="-1" Length="2243.6" Area="342402.0" LengthMicrons="1047.0" AreaMicrons="74567.5" Text="Benign" NegativeROA="0" InputRegionId="0" Analyze="1" DisplayId="1">
<Attributes>
<Attribute Name="1" Id="0" Value="Benign"/>
</Attributes>
<Vertices>
<Vertex X="7398" Y="21614" Z="0"/>
<Vertex X="7396" Y="21614" Z="0"/>
<Vertex X="7392" Y="21636" Z="0"/>
<Vertex X="7388" Y="21656" Z="0"/>
<Vertex X="7386" Y="21660" Z="0"/>
<Vertex X="7384" Y="21666" Z="0"/>
<Vertex X="7384" Y="21670" Z="0"/>
<Vertex X="7384" Y="21672" Z="0"/>
<Vertex X="7384" Y="21674" Z="0"/>
<Vertex X="7382" Y="21674" Z="0"/>
<Vertex X="7382" Y="21676" Z="0"/>
<Vertex X="7382" Y="21678" Z="0"/>
<Vertex X="7382" Y="21680" Z="0"/>
<Vertex X="7382" Y="21682" Z="0"/>
<Vertex X="7380" Y="21682" Z="0"/>
<Vertex X="7380" Y="21684" Z="0"/>
<Vertex X="7380" Y="21686" Z="0"/>
<Vertex X="7380" Y="21688" Z="0"/>
<Vertex X="7380" Y="21690" Z="0"/>
<Vertex X="7378" Y="21690" Z="0"/>
<Vertex X="7378" Y="21694" Z="0"/>
<Vertex X="7378" Y="21696" Z="0"/>
</Vertices>
</Region
</Regions>
<Plots/>
</Annotation>
Из этого файла я должен извлечь минимальную и максимальную X и Y вершины.
Я новичок в Python и впервые разбираю xml-файлы
Я попробовал приведенный ниже код для извлечения минимального х
xml_file = os.path.join(xml_path, f)
print(xml_file)
tree = ET.parse(xml_file)
root = tree.getroot()
#doc = etree.parse(filename)
for elem in root:
#print(elem,'-1')
for child in elem:
#print(child,'-2')
if child.tag=='Regions':
for gchild in child:
if gchild.tag=='Region':
id=gchild.get('Id')
print(id)
for subelem in gchild:
current_sub=subelem.tag
print(current_sub,'-4')
if current_sub=='Vertices':
for vertex in subelem:
minx=100000
for v in vertex.tag:
x=int(vertex.get('X'))
if x<minx:
minx=x
else:
continue
print(minx)
Но я не получаю желаемых результатов. Есть ли более короткий и чистый способ сделать это в Python. С этим кодом я получаю все X координаты в качестве моего вывода для minx
Аналогичным образом я должен получить значения для max_x , min_y и max_x , чтобы создать ограничивающий прямоугольник.