问题描述
我有一个如下的 XML 文件
$file = "\Input\27532.csv"
$outFile = "\Output\27532.csv"
$content= Get-Content $file | Where-Object { ($_ -notmatch '24') -and ($_ -notmatch '67') } | Set-Content $outfile
我使用 ElementTree 来获取所需的属性。作为示例代码,我阅读了单列。
<D1>
<RECORD>
<NODE>XT-300</NODE>
<ST_DURATION>10</ST_DURATION>
<DT_VAL>PBM98XX</DT_VAL>
<ST_VAL>98987</ST_VAL>
<EXIST>Yes</EXIST>
</RECORD>
<RECORD>
<NODE>XT-400</NODE>
<ST_DURATION>10</ST_DURATION>
<DT_VAL>CVB98XX</DT_VAL>
<ST_VAL>65987</ST_VAL>
<EXIST>Yes</EXIST>
</RECORD>
</D1>
我希望动态解析 xml。意思是,我应该在单独的配置文件中提供这些列,并在代码中动态提取这些列。我需要这种动态解析,因为我对其他输入 xml 文件有类似的 xml 结构。只是列名不同。下面是第二个 xml 的示例。
import xml.etree.ElementTree as Xet
import pandas as pd
cols = ["NODE","ST_DURATION","DT_VAL","ST_VAL","EXIST"]
rows = []
xmlparse = Xet.parse('DEVICE1.xml')
root = xmlparse.getroot()
for i in root:
node = i.find("NODE").text
rows.append({"NODE": node})
df = pd.DataFrame(rows,columns=cols)
df.to_csv('output.csv')
更新动态解析所需的新xml。
<D1>
<RECORD>
<ELEC>EL-13</ELEC>
<VAL>10</VAL>
<POWER>Max</POWER>
<WIRING>2.3</WIRING>
<ENABLED>Yes</ENABLED>
</RECORD>
<RECORD>
<ELEC>EL-14</ELEC>
<VAL>30</VAL>
<POWER>Max</POWER>
<WIRING>1.1</WIRING>
<ENABLED>Yes</ENABLED>
</RECORD>
</D1>
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)