python - 使用 Petl 读取 XML 文件
问题描述
我正在尝试将 XML 文件中的信息解析为已经使用 Petl 从另一个 CSV 文件创建的表,并且在fromxml()
函数的语法上遇到问题。
XML 文件包含:
<Locations>
<qld_location>
<Suburb>Brisbane-Central</Suburb>
<Lat>-27.46758</Lat>
<Long>153.027892</Long>
</qld_location>
<qld_location>
<Suburb>Robertson</Suburb>
<Lat>-27.565733</Lat>
<Long>153.057213</Long>
</qld_location>
<qld_location>
<Suburb>Logan-Village</Suburb>
<Lat>-27.767054</Lat>
<Long>153.116881</Long>
</qld_location>
</Locations>
我目前有一张桌子:
import petl as etl
table = (
etl
.fromcsv('QLD_Health_Care_Practices.csv')
.convert('Practice_Name', 'upper')
.convert('Suburb', str)
.convert('State', str)
.convert('Postcode', str)
)
+-----------------------------------+--------------------+-------+----------+
| Practice_Name | Suburb | State | Postcode |
+===================================+====================+=======+==========+
| 'BRISBANE CENTRE HEALTH SERVICES' | 'Brisbane-Central' | 'QLD' | '4000' |
+-----------------------------------+--------------------+-------+----------+
| 'ROBERTSON FAMILY PRACTICE' | 'Robertson' | 'QLD' | '4109' |
+-----------------------------------+--------------------+-------+----------+
| 'LOGAN VILLAGE CLINIC' | 'Logan-Village' | 'QLD' | '4207' |
+-----------------------------------+--------------------+-------+----------+
| 'IPSWICH HEALTH CLINIC' | 'Ipswich' | 'QLD' | '4305' |
+-----------------------------------+--------------------+-------+----------+
| 'CATTLE CREEK CLINIC' | 'Cattle Creek' | 'QLD' | '4407' |
+-----------------------------------+--------------------+-------+----------+
并希望在 XML 文件的新列中添加经度和纬度。
我正在尝试使用该功能:
table1= (etl.fromxml('QLD_Locations.xml', 'Locations', 'qld_location', 'Suburb', 'Lat', 'Long')
但是在理解这种 XML 语法所需的参数时遇到了麻烦。
任何帮助将不胜感激,在此先感谢。
解决方案
“扁平”参数列表.fromxml()
仅在您还具有扁平类型的 XML 结构时才有效,其中所有数据列都具有相同的名称:
<ROOT>
<RECORD>
<DATA /><DATA /><DATA /><DATA /><DATA />
</RECORD>
</ROOT>
这可以提取为
etl.fromxml('file.xml', 'RECORD', 'DATA')
要从具有各种列名或嵌套的更复杂的结构中提取数据,例如:
<ROOT>
<RECORD>
<A /><B /><C /><D /><E />
</RECORD>
</ROOT>
在这里,您必须使用 dict 明确指定要提取的每一列:
etl.fromxml('file.xml', 'RECORD', {
'Column 1': 'A',
'Column 2': 'B',
'Column 3': 'C',
'Column 4': 'D',
'Column 5': 'E',
})
其中 'A'、'B'、'C' 等是相对于RECORD
.
推荐阅读
- ios - 在 SWIFT 中关闭 Popover 表视图后传递值
- python - 使用python 3连接hive
- xslt - 如何将 id 动态分配给我的 for 循环内的 xsl fo 块?
- ruby-on-rails - 使用 pg 搜索在 associated_against 之前过滤关联记录
- javascript - 在数独的文本框中放置仅显示文本
- java - 在java中将带有
(但没有关闭br标签)标签的HTML转换为PDF - python - 如何从python中的列表中删除相同类型的元素
- c# - C# 如何在另一个 Linq 语句中的 XmlAttributeCollection 上使用 Linq?
- git - 用于小型网站开发的简单 GIT 工作流程
- python - 检查特定字符串的 Dataframe 并返回找到该字符串的列的列标题