首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Python + MySQLdb executemany

Python + MySQLdb executemany
EN

Stack Overflow用户
提问于 2009-06-10 10:09:58
回答 2查看 14.2K关注 0票数 7

我使用Python及其MySQLdb模块将一些测量数据导入Mysql数据库。我们拥有的数据量相当大(目前大约有250 MB的csv文件,还有更多)。

目前我使用cursor.execute(.)导入一些元数据。这是没有问题的,因为只有少数几个条目。

问题是,当我尝试使用cursor.executemany()导入大量实际测量数据时,MySQLdb会引发一个

代码语言:javascript
复制
TypeError: not all arguments converted during string formatting

我目前的代码是

代码语言:javascript
复制
def __insert_values(self, values):
    cursor = self.connection.cursor()
    cursor.executemany("""
        insert into values (ensg, value, sampleid)
        values (%s, %s, %s)""", values)
    cursor.close()

其中values是一个元组列表,每个元组包含三个字符串。有什么好主意吗?

编辑:

这些值是由

代码语言:javascript
复制
yield (prefix + row['id'], row['value'], sample_id)

然后将行和迭代器从csv.DictReader读取到一个列表中,每次读取1000行。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2009-06-16 14:54:47

回顾而言,这是一个非常愚蠢但很难发现的错误。值是sql中的一个关键字,因此表名值需要它周围的引号。

代码语言:javascript
复制
def __insert_values(self, values):
    cursor = self.connection.cursor()
    cursor.executemany("""
        insert into `values` (ensg, value, sampleid)
        values (%s, %s, %s)""", values)
    cursor.close()
票数 8
EN

Stack Overflow用户

发布于 2009-06-10 11:02:20

您收到的消息表明,在executemany()方法中,有一个转换失败。检查values列表中是否有大于3的元组。

为了进行快速核查:

代码语言:javascript
复制
max(map(len, values))

如果结果大于3,则使用筛选器定位您的坏元组:

代码语言:javascript
复制
[t for t in values if len(t) != 3]

或者,如果您需要索引:

代码语言:javascript
复制
[(i,t) for i,t in enumerate(values) if len(t) != 3]
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/974702

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档