时间:2021-05-22
MySQLdb默认查询结果都是返回tuple,输出时候不是很方便,必须按照0,1这样读取,无意中在网上找到简单的修改方法,就是传递一个cursors.DictCursor就行。
默认程序:
import MySQLdbdb = MySQLdb.connect(host='localhost', user='root', passwd='123456', db='test')cur = db.cursor()cur.execute('select * from user')rs = cur.fetchall()print rs# 返回类似如下# ((1000L, 0L), (2000L, 0L), (3000L, 0L))修改后:
或者也可以用下面替换connect和cursor部分
db = MySQLdb.connect(host='localhost', user='root', passwd='123456', db='test')
cur = db.cursor(cursorclass=MySQLdb.cursors.DictCursor)
我的实践:
输出为元组类型:
import pymysql db = pymysql.connect("localhost", "root", "123456", "filestore")cursor = db.cursor()sql='select * from tablelist where id>%s' %4#查询方法一cursor.execute(sql)result=cursor.fetchall()print('result',result) sql2='select * from tablelist where id>%s'values=('4') # 此处为元组类型#查询方法二cursor.execute(sql2,values)result2=cursor.fetchall()print('result2',result2)id_list=[]tablename_list=[]tabletime_lsit=[]cursor.execute('select * from tablelist where id>%s',[4,])result3=cursor.fetchall()print('type(result3)',type(result3))#对((6, 'engineeringdata20180901', '1535731200'),)类型数据的提取for i in range(len(result3)): id_list.append(result3[i][0]) tablename_list.append(result3[i][1]) tabletime_lsit.append(result3[i][2])print(id_list)print(tabletime_lsit)print(tablename_list)cursor.close()db.close()#输出结果:result ((6, 'engineeringdata20180901', '1535731200'), (618, 'engineeringdata20180904', '1535990400'))result2 ((6, 'engineeringdata20180901', '1535731200'), (618, 'engineeringdata20180904', '1535990400'))type(result3) <class 'tuple'>[6, 618]['1535731200', '1535990400']['engineeringdata20180901', 'engineeringdata20180904']输出为list类型:
list_id=[]list_tablename=[]list_tabletime=[]list=get_list('select * from tablelist where id>%s',[4])print('list:',list)# 对[{'id': 6, 'tablename': 'engineeringdata20180901', 'tabletime': '1535731200'},]类型数据的提取for i in range(len(list)): print(list[i]) list_id.append(list[i]['id']) list_tablename.append(list[i]['tablename']) list_tabletime.append(list[i]['tabletime'])print('list_id:',list_id)print('list_tabletime:',list_tabletime)print('list_tablename:',list_tablename)# 输出结果为:list: [{'id': 6, 'tablename': 'engineeringdata20180901', 'tabletime': '1535731200'}, {'id': 618, 'tablename': 'engineeringdata20180904', 'tabletime': '1535990400'}]{'id': 6, 'tablename': 'engineeringdata20180901', 'tabletime': '1535731200'}{'id': 618, 'tablename': 'engineeringdata20180904', 'tabletime': '1535990400'}list_id: [6, 618]list_tabletime: ['1535731200', '1535990400']list_tablename: ['engineeringdata20180901', 'engineeringdata20180904']补充知识:python下 将 pymysql 返回的元组数据转换为列表
我就废话不多说了,大家还是直接看代码吧!
from itertools import chain...sql="select elems from table"cursor.execute(sql)elems = cursor.fetchall()resultlist = list(chain.from_iterable(elems))...以上这篇python 数据库查询返回list或tuple实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
Python的MySQLdb模块是Python连接MySQL的一个模块,默认查询结果返回是tuple类型,只能通过0,1..等索引下标访问数据默认连接数据库:复
本文实例讲述了thinkPHP5实现的查询数据库并返回json数据。分享给大家供大家参考,具体如下:TP5实现查询数据库返回json数据(返回json数据函数实
什么是python的迭代如果给定一个list或tuple,我们可以通过for循环来遍历这个list或tuple,这种遍历我们称为迭代(Iteration)。(在
本文实例讲述了Android创建或升级数据库时执行的语句,如果是创建或升级数据库,请使用带List参数的构造方法,带SQL语句的构造方法将在数据库创建或升级时执
数据库表是一个二维表,包含多行多列。把一个表的内容用Python的数据结构表示出来的话,可以用一个list表示多行,list的每一个元素是tuple,表示一行记