我遇到了很多麻煩Python中的XML文件轉換爲CSV。我已經看過很多論壇,嘗試了lxml和xmlutils.xml2csv,但我無法讓它工作。它是Garmin GPS設備的GPS數據。XML到CSV在Python
下面是我的XML文件的樣子,縮短課程:
<?xml version="1.0" encoding="utf-8"?>
<gpx xmlns:tc2="http://www.garmin.com/xmlschemas/TrainingCenterDatabase/v2" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:tp1="http://www.garmin.com/xmlschemas/TrackPointExtension/v1" xmlns="http://www.topografix.com/GPX/1/1" version="1.1" creator="TC2 to GPX11 XSLT stylesheet" xsi:schemaLocation="http://www.topografix.com/GPX/1/1 http://www.topografix.com/GPX/1/1/gpx.xsd http://www.garmin.com/xmlschemas/TrackPointExtension/v1 http://www.garmin.com/xmlschemas/TrackPointExtensionv1.xsd">
<trk>
<name>2013-12-03T21:08:56Z</name>
<trkseg>
<trkpt lat="45.4852855" lon="-122.6347885">
<ele>0.0000000</ele>
<time>2013-12-03T21:08:56Z</time>
</trkpt>
<trkpt lat="45.4852961" lon="-122.6347926">
<ele>0.0000000</ele>
<time>2013-12-03T21:09:00Z</time>
</trkpt>
<trkpt lat="45.4852982" lon="-122.6347897">
<ele>0.2000000</ele>
<time>2013-12-03T21:09:01Z</time>
</trkpt>
</trkseg>
</trk>
</gpx>
有我的巨大的XML文件的幾個TRK標籤,但我可以管理它們分離出來 - 他們代表着不同的「段」或在GPS設備上旅行。我要的是繪製這樣的一個CSV文件:
LAT LON TIME ELE
45.4... -122.6... 2013-12... 0.00...
... ... ... ...
這裏是我到目前爲止的代碼:
## Call libraries
import csv
from xmlutils.xml2csv import xml2csv
inputs = "myfile.xml"
output = "myfile.csv"
converter = xml2csv(inputs, output)
converter.convert(tag="WHATEVER_GOES_HERE_RENDERS_EMPTY_CSV")
這是另一種選擇的代碼。它僅僅是輸出沒有數據,只是頭lat
和lon
CSV文件。
import csv
import lxml.etree
x = '''
<?xml version="1.0" encoding="utf-8"?>
<gpx xmlns:tc2="http://www.garmin.com/xmlschemas/TrainingCenterDatabase/v2" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:tp1="http://www.garmin.com/xmlschemas/TrackPointExtension/v1" xmlns="http://www.topografix.com/GPX/1/1" version="1.1" creator="TC2 to GPX11 XSLT stylesheet" xsi:schemaLocation="http://www.topografix.com/GPX/1/1 http://www.topografix.com/GPX/1/1/gpx.xsd http://www.garmin.com/xmlschemas/TrackPointExtension/v1 http://www.garmin.com/xmlschemas/TrackPointExtensionv1.xsd">
<trk>
<name>2013-12-03T21:08:56Z</name>
<trkseg>
<trkpt lat="45.4852855" lon="-122.6347885">
<ele>0.0000000</ele>
<time>2013-12-03T21:08:56Z</time>
</trkpt>
<trkpt lat="45.4852961" lon="-122.6347926">
<ele>0.0000000</ele>
<time>2013-12-03T21:09:00Z</time>
</trkpt>
<trkpt lat="45.4852982" lon="-122.6347897">
<ele>0.2000000</ele>
<time>2013-12-03T21:09:01Z</time>
</trkpt>
</trkseg>
</trk>
</gpx>
'''
with open('output.csv', 'w') as f:
writer = csv.writer(f)
writer.writerow(('lat', 'lon'))
root = lxml.etree.fromstring(x)
for trkpt in root.iter('trkpt'):
row = trkpt.get('lat'), trkpt.get('lon')
writer.writerow(row)
我該怎麼做?請意識到我是一個新手,所以更全面的解釋將超級棒!
你作爲輸出得到了什麼? 'xmlutils'沒有正確讀取'lat'和'lon'屬性?描述輸出與預期的不同之處。快速瀏覽文檔表明標籤應該是'trkpt'。 – ChrisP
當我用'trkpt'作爲指示標籤運行程序時,程序完成時沒有任何錯誤消息,並生成一個空的.csv文件。我不知道xmlutils是不是正確讀取'lat'或'lon',因爲我不知道程序是如何工作的,並且沒有錯誤信息。我預計產出至少會產生「時間」和「電子產品」,但事實並非如此。 – plnnr
我沒說清楚嗎?我不明白xmlutils或其中的任何工作。文檔很差。我可以做他們提供的示例文件,但是嵌入元素中的標籤/項目(即'trkpt'中的'lat'和'lon'),我只是不明白。在這個愚蠢的時刻,我一直坐在電腦前約12小時。 – plnnr