无法使用字典

时间:2015-12-09 09:10:12

标签: python dictionary sqlite

我正在尝试创建一个使用SQLite3将行插入dictionary数据库的函数。

我在这里找到了一个方法来做到这一点,但遗憾的是它不起作用。有一些我无法弄清楚的问题。

def insert_into_table(self,data):

    for key in data.keys(): # ADDING COLUMNS IF NECESSARY
        columns = self.get_column_names()
        column = key.replace(' ','_')
        if column not in columns:
            self.cur.execute("""ALTER TABLE vsetkyfirmy ADD COLUMN {} TEXT""".format(column.encode('utf-8')))
            self.conn.commit()
    new_data={}

    for v,k in data.iteritems(): # new dictionary with remaden names (*column = key.replace(' ','_'))
        new_data[self.remake_name(v)]=k

    columns = ', '.join(new_data.keys())
    placeholders = ':'+', :'.join(new_data.keys())
    query = 'INSERT INTO vsetkyfirmy (%s) VALUES (%s)' % (columns, placeholders)
    self.cur.execute(query, new_data)
    self.conn.commit()

例外:

self.cur.execute(query, new_data)
sqlite3.ProgrammingError: You did not supply a value for binding 1.

当我打印querynew_data时,一切似乎都正确无误:

INSERT INTO vsetkyfirmy (Obchodné_meno, IČ_DPH, Sídlo, PSČ, Spoločník, IČO, Základné_imanie, Konateľ, Ročný_obrat, Dátum_vzniku, Právna_forma) VALUES (:Obchodné_meno, :IČ_DPH, :Sídlo, :PSČ, :Spoločník, :IČO, :Základné_imanie, :Konateľ, :Ročný_obrat, :Dátum_vzniku, :Právna_forma)
{u'Obchodn\xe9_meno': 'PRspol. s r.o.', u'I\u010c_DPH': 'S9540', u'S\xeddlo': u'Bansk\xe1 Bystrica, Orembursk\xe1 2', u'PS\u010c': '97401', u'Spolo\u010dn\xedk': u'Dana Dzurianikov\xe1', u'I\u010cO': '3067', u'Z\xe1kladn\xe9_imanie': u'142899 \u20ac', u'Konate\u013e': 'Miroslav Dz', u'Ro\u010dn\xfd_obrat': '2014: 482 EUR', u'D\xe1tum_vzniku': '01.12.1991 ', u'Pr\xe1vna_forma': u'Spolo\u010dnos\u0165 s ru\u010den\xedm obmedzen\xfdm'}

编辑:所以我试图从查询中删除':',看起来像:

INSERT INTO vsetkyfirmy (Obchodné_meno, IČ_DPH, Sídlo, PSČ, Spoločník, IČO, Základné_imanie, Konateľ, Ročný_obrat, Dátum_vzniku, Právna_forma) VALUES (Obchodné_meno, IČ_DPH, Sídlo, PSČ, Spoločník, IČO, Základné_imanie, Konateľ, Ročný_obrat, Dátum_vzniku, Právna_forma)

它返回sqlite3.OperationalError: no such column: Obchodné_meno

我不知道问题出在哪里,可能是编码吗?

1 个答案:

答案 0 :(得分:0)

您在创建表时调用encode('utf-8'),但在插入时不调用。

SQLite确实使用UTF-8,但sqlite3模块自动处理从/到内部Unicode字符串编码的转换。不要尝试手动重新编码。