玩蛇网提供最新Python编程技术信息以及Python资源下载!

MySQL小问题,fetchone怎么返回到dict中的方法?

初学Python,菜鸟一枚

看到Python中的fetchall可以简写成如下方式:

infos = [(dict(name=row[1], sex=row[2],age=row[3]) for row in cur.fetchall())]

如果是fetchone,有没有类似的简写?

错误信息补充

@蓝皮鼠

fetchone()返回的tuple为单独一行结果集,对其迭代相当于在遍历一行中的各列
一般只在处理确定只有一行数据的情景下用
多行的情况,还是用fetchall,如果非要用,大概这样

rs = []
while True:
    r = cur.fetchone()
    if not r:
        break
    d = dict(zip(('a', 'b'), r))
    rs.append(d)

很丑陋,对不对

首先这个问题写的不是很清楚,这个fetchall/fetchone应该是sqlite模块的操作,而不是所谓的python中:-)。然后fetchall/fetchone的差异仅仅是一个获取所有记录,一个获取单条记录,所以这两种没有什么区别,这里的写法也是一致的,BTW这个完全可以自己测试下
=====================
OK,我明白jimmy的意思了,那确实是不行的,因为fetchall返回的是这样的格式

([a,b,c],[e,f,g],[g,i,j])

所以你使用

for row in cur.fetchall()

可以取到

[a,b,c]和[e,f,g]和[h,i,j]

而fetchone得到的是

(a,b,c)

所以要得到这样的效果可以,注意最后一个,:

[dict(name = row[0],...) for row in [cur.fetchone(),]]

玩蛇网文章,转载请注明出处和文章网址:https://www.iplaypy.com/wenda/wd20469.html

相关文章 Recommend

玩蛇网Python互助QQ群,欢迎加入-->: 106381465 玩蛇网Python新手群
修订日期:2017年05月23日 - 17时32分04秒 发布自玩蛇网

您现在的位置: 玩蛇网首页 > Python问题解答 > 正文内容
我要分享到:

必知PYTHON教程 Must Know PYTHON Tutorials

必知PYTHON模块 Must Know PYTHON Modules