第一種方法,不用高級屬性,本身硬寫一個函數mysql
import pymysql db=pymysql.connect(host="",user="",passwd="",db="",post=3306,charset="utf8"); str="select * from db1 where usrID="";"; cursor=db.cursor() try: cursor.excute(str) index=cursor.description #列描述 result=[] db.commit() for res in cursor.fetchall(): #返回的所有結果 row={} for i in range(len(index)-1): row[index[i][0]]=res[i] result.append(row) #result是最後要的dict數組 except: db.rollback() cursor.close() db.close()
第二種方法,這種方法涉及到列表的嵌套函數,可是最好用的sql
import pymysql db=pymysql.connect(host="127.0.0.1", user="root", password="", database="data", port=3306, charset='utf8',) str="select * from userinfo ;" #str="select * from userinfo where certificate_no='20200317001' ;" cursor=db.cursor() try: cursor.execute(str) desc = cursor.description # 獲取字段的描述 data_dict = [dict(zip([col[0] for col in desc], row)) for row in cursor.fetchall()] # row是數據庫返回的一條一條記錄,外側的這個for是大循環,裏邊的for提取了數據列描述,
#和一條數據合成一個字典,外側循環將多條記錄循環成字典數組
print(data_dict) except: db.rollback() cursor.close() db.close()
第三種方法用迭代函數,這個既不如第一個,也不如第二個,有點不三不四了數據庫
import pymysql db=pymysql.connect(host="",user="",passwd="",db="",post=3306,charset="utf8"); str="select * from db1 where usrID="";"; cursor=db.cursor() def new2dict(new): #迭代函數 return dict(zip([x[0] for x in cursor.description],[x for x in new])) #zip函數 try: cursor.excute(str) news_list=list(map(new2dict,cursor.fetchall())) #news_list是轉換後的dict數組 這裏有map函數 except: db.rollback() cursor.close() db.close()