我正在使用Python脚本从Web服务器读取xml数据。我还想将数据存储在sqlite数据库中,但我仍然不知道如何在存储数据之前解析xml数据。
以下是当前代码:
import xbmc
import xbmcgui
import xbmcaddon
import urllib2
ADDON = xbmcaddon.Addon(id = 'script.myaddon')
class MyScript(xbmcgui.WindowXML):
def __new__(cls):
return super(MyScript, cls).__new__(cls, 'script-menu.xml', ADDON.getAddonInfo('path'))
def onInit(self):
url = ADDON.getSetting('ontv.url')
req = urllib2.Request(url)
response = urllib2.urlopen(req)
data = response.read()
response.close()
profilePath = xbmc.translatePath(os.path.join('special://userdata/addon_data/script.tvguide', ''))
if os.path.exists(profilePath):
profilePath = profilePath + 'source.db'
con = lite.connect(profilePath)
cur = con.cursor()
cur.execute('CREATE TABLE IF NOT EXISTS data (channels, programme_title, programme_time, description, logo_url)')
cur.close()
return data
cSetVisible(self,4201,True)
这是settings.xml:
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<settings>
<category label="30101">
<setting id="source" label="30101" type="labelenum" default="YouSee.tv"
values="YouSee.tv|XMLTV|ONTV.dk" />
<setting id="youseetv.category" label="30102" type="labelenum" default="Danske"
values="Danske|Filmkanaler|Grundpakken|Mellempakken|Fuldpakken|Nordiske|Engelske|Tyske|Latinske|Slaviske|Tyrkiske|Kurdiske|Arabiske|Asiatiske"
visible="eq(-1,0)" />
<setting id="program.background.enabled" label="30107" type="bool" default="true" visible="eq(-2,0)"/>
<setting id="english.enabled" value="true"/>
<setting id="french.enabled" value="false"/>
<setting id="xmltv.file" label="30103" type="file" visible="eq(-3,1)" />
<setting id="xmltv.logo.folder" label="30116" type="folder" visible="eq(-4,1)"/>
<setting id="ontv.url" label="30117" type="text" visible="eq(-5,2)" default="http://ontv.dk/xmltv/c81e728d9d4c2f636f067f89cc14862c"/>
</category>
</settings>
我正在阅读此网站的xml数据:http://ontv.dk/xmltv/c81e728d9d4c2f636f067f89cc14862c
我知道如何用response.read()
读取xml数据,但我仍然不知道如何解析xml数据以存储在数据库中。
如何解析xml数据并将其存储在数据库中?
答案 0 :(得分:1)
正如其他人提到的,我也建议lxml
如果你想查看xml结构并以非常pythonic的方式使用它,请查看
lxml objectify
或
untangle
使用这些库,您应该从XML中获取数据。也许请记住,对于更大的XML文件,这不是最好和最快的方法。