Python使用pymysql小技巧

只有经受过冰霜的人,才会领悟太阳的温暖,只有饱尝人生艰辛的人,才会懂得生命的可贵。早安!

在使用pymysql的时候,通过fetchall()或fetchone()可以获得查询结果,但这个返回数据是不包含字段信息的(不如php方便)。查阅pymysql源代码后,其实获取查询结果源代码也是非常简单的,直接调用cursor.description即可。

譬如:

db = pymysql.connect(...)
cur = db.cursor()
cur.execute(sql)
print(cur.description)
result = cur.fetchall()
data_dict=[]
for field in cur.description:
  data_dict.append(field[0])
print(data_dict)

在pymysql的 pymysql/cursors.py 中,找到 class Cursor 可以看到如下代码:

def __init__(self, connection):
  self.connection = connection
  self.description = None
  self.rownumber = 0
  self.rowcount = -1
  self.arraysize = 1
  self._executed = None
  self._result = None
  self._rows = None
  self._warnings_handled = False

因此,调用 cur.rowcount 是可以迅速返回查询结果记录数的,不需要通过 len() 获得。

本文Python使用pymysql小技巧到此结束。黑夜的转弯是白天,愤怒的转弯是快乐,所以有的时候让心情转个弯就好了。小编再次感谢大家对我们的支持!

您可能有感兴趣的文章
关于Python形参打包与解包小技巧分享

简单了解python代码优化小技巧

pandas 使用均值填充缺失值列的小技巧分享

详解10个可以快速用Python进行数据分析的小技巧

11个Python Pandas小技巧让你的工作更高效(附代码实例)