Sqlite and Python — return a dictionary using fetchone()?

后端 未结 8 1724
没有蜡笔的小新
没有蜡笔的小新 2021-01-31 04:03

I\'m using sqlite3 in python 2.5. I\'ve created a table that looks like this:

   create table votes (
      bill text,
      senator_id text,
      vote text)
<         


        
8条回答
  •  遥遥无期
    2021-01-31 04:25

    I was recently trying to do something similar while using sqlite3.Row(). While sqlite3.Row() is great for providing a dictionary-like interface or a tuple like interface, it didn't work when I piped in the row using **kwargs. So, needed a quick way of converting it to a dictionary. I realised that the Row() object can be converted to a dictionary simply by using itertools.

    Python 2:

    db.row_factory = sqlite3.Row
    dbCursor = db.cursor()
    dbCursor.execute("SELECT * FROM table")
    row = dbCursor.fetchone()
    
    rowDict = dict(itertools.izip(row.keys(), row))
    

    Or in Python 3, more simply:

    dbCursor = db.cursor()
    dbCursor.execute("SELECT * FROM table")
    row = dbCursor.fetchone()
    rowDict = dict(zip([c[0] for c in dbCursor.description], row))
    

    Similarly, you can use the dbCursor.fetchall() command and convert the entire set of rows to a list of dictionaries in a for loop.

提交回复
热议问题