2016-08-02 2 views
0

파이썬에서 하나 이상의 루트가있는 xml 문서를 파싱하는 방법을 연구했지만 성공하지 못했습니다. 누구든지이 작업을 수행하는 데 도움이되는 사이트를 알고 있습니까? 아니면이 작업을 수행 할 수 있는지 여부에 대해 어떤 가벼움이 있습니까? 아래 XML 파일과 Python 코드가 있습니다. 나는 'NoneType'객체에 파이썬 코드의 읽기 루프에 'text'속성이 없다는 것을 알게된다.파이썬에서 여러 손자로 xml doc을 파싱

XML 파일 :

<ThursdayDay12> 

<event> 
<title>Refrigerator/freezer</title> 
<startHour>11</startHour> 
<startMinute>00</startMinute> 
<duration units = 'min'>780</duration> 
<load units = 'W'>33.77</load> 
<comment> 
'HANOVER HANRT30C Model' 
</comment> 
</event> 

<event> 
<title>Temperature</title> 
<startHour>7</startHour> 
<startMinute>30</startMinute> 
<duration units = 'min'>990</duration> 
<load units = 'W'>3520</load> 
<comment> 
'Assume AC requirement for house is 1 TR=3.52 kW' 
</comment> 
</event> 

<event> 
<title>Indoor lighting</title> 
<startHour>20</startHour> 
<startMinute>00</startMinute> 
<duration units = 'min'>240</duration> 
<load units = 'W'>250</load> 
<comment> 
'LED lighting for 4 rooms' 
</comment> 
</event> 

</ThursdayDay12> 


<FridayDay13> 

<event> 
<title>TV</title> 
<startHour>19</startHour> 
<startMinute>30</startMinute> 
<duration units = 'min'>150</duration> 
<load units = 'W'>3.96</load> 
<comment> 
'VIZIO E28h-C1 model rated at 34.7 kWh/yr' 
</comment> 
</event> 

<event> 
<title>Heat water for showers</title> 
<startHour>19</startHour> 
<startMinute>30</startMinute> 
<duration units = 'min'>150</duration> 
<load units = 'W'>1385</load> 
<comment></comment> 
</event> 

</FridayDay13> 

</SD2017NominalEnergyUse> 

파이썬 코드 :

import xml.etree.ElementTree as ET 

tree = ET.parse('SD2017NominalEnergyUse.xml') 
root = tree.getroot() 


title, start, end, load, duration = [],[],[],[],[] 

for child in root: 
    for grandchild in child: 

     title.append(child.find('title').text) 

     sh = int(child.find('startHour').text) 
     sm = int(child.find('startMinute').text) 
     duration.append(float(child.find('duration').text)) 
     start.append(sh*60+sm) 
     end.append(start[-1] + duration[-1]) 
     load.append(float(child.find('load').text)) 

P = 0.0 
for i in range(len(root)): 
    P = P+load[i] 

print(P) 

답변

1

당신이 xml.dom 또는 minidom 시도?

+0

어린이 및 손자 속성이있는 xml 파일을 구문 분석하는 데 도움이되는 내용을 찾지 못했습니다. –

+0

@ZachThomas [XML을 Python으로 구문 분석하는 방법] (http://stackoverflow.com/questions/1912434/how-do- i-parse-xml-in-python) – Frangipanes

+0

네, xml 파일을 손자 파트로 파싱하는 방법을 다루지는 않습니다. etree의 구문 분석은 xml 파일의 손자 속성과 작동하지 않습니다. –