簡體   English   中英

如何正確地將Python“列表列表”映射到SQL表(使用SQLite3構建)?

[英]How do I correctly map a Python “list of lists” into an SQL table (built with SQLite3)?

我的數據來自包含儀器讀數的XML解析器。 數據樣本如下:

cimReading = [['2012-08-15 10:05:13.101485', ['0x46'], ['0x32'], ['1.234'], ['5.678'], ['9.123'],
 ['4.567'], ['0x98'], ['0x97']], 
['2012-08-15 10:05:13.101979', ['0x47'], ['0x33'], ['8.901'], ['2.345'], ['6.789'], 
['0.123'], ['0x96'], ['0x95']]]

我正在嘗試遍歷列表項並將它們放在一個表cim76_dmt ,該表先前在Python中使用sqlite3定義。 這是我用來嘗試這樣做的代碼:

for devList in cimReading:
    print devList
    cim76TabPopulate.execute('INSERT INTO cim76_dmt VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)', 
            devList)
BenchDB.commit()
cim76TabPopulate.close() 

這是我在執行時收到的錯誤消息:

['2012-08-15 10:40:21.110140', ['0x46'], ['0x32'], ['1.234'], ['5.678'], ['9.123'], ['4.567'], ['0x98'], ['0x97']]
EXCEPTION...
(<class 'sqlite3.InterfaceError'>, InterfaceError('Error binding parameter 1 - probably unsupported type.',), <traceback object at 0x1007a7518>)

所以,我在將列表項映射到SQL表字段時遇到問題。 我認為應該有一種方法可以做到這一點,但另一種可能性是調整XML解析,因此我為每條記錄生成一個包含多個字符串的列表。 我歡迎任何關於此的建議或意見。

提前致謝!

您的問題是第一個之后的所有參數都是列表,而不是字符串或整數。 部分贏得錯誤消息,抱怨unsupported type抱怨數據元素['0x46']

你需要更多地按摩你的數據; 你想將['0x46']解包為'0x46' 這需要對示例數據中單個長度列表中的其他數據元素進行。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM