在pycharm运行程序的时候调用数据库报错
**问题相关代码:
**
def get_user_items(table_name):
sql = 'select `用户`,`索引` from %s'%table_name
result = select_data(sql)
data = {}
for i in result:
data.setdefault(str(i['用户']),[])
data[str(i['用户'])].append(str(i['索引']))
# print(data)
return dict(data)
然后调用select函数,这个函数写在另一个文件里,如下
def select_data(sql):
db = connect_db()
cursor = db.cursor()
cursor.execute(sql)
result = cursor.fetchall()
db.commit()
db.close()
desp_list = [i[0] for i in cursor.description] # 获取字段列表
data = []
for i in result:
data.append(dict(zip(desp_list,i)))
return data
Traceback (most recent call last):
File "C:/Users/86181/Desktop/trip-main/trip-python/utils/action.py", line 53, in <module>
artical_item_base_data = get_item_base_data('artical_action')
File "C:/Users/86181/Desktop/trip-main/trip-python/utils/action.py", line 22, in get_item_base_data
pre_data = get_user_items(table_name)
File "C:/Users/86181/Desktop/trip-main/trip-python/utils/action.py", line 9, in get_user_items
result = select_data(sql)
File "C:\Users\86181\Desktop\trip-main\trip-python\utils\dbutils.py", line 28, in select_data
cursor = db.cursor()
AttributeError: 'str' object has no attribute 'cursor'
连接数据库出错
object supporting the buffer API required
进程已结束,退出代码为 1
本地数据库已经连接上了,但是跑到这里就会突然报错,本人猜测可能是数据库内表的参数设置的不匹配。但是为什么是游标报错呢?
刚学数据库和python不久,求答主指导细一点谢谢啦
db = connect_db()这里调用的函数返回是一个字符串类型数据,无法创建游标对象。db应该是一个数据库连接对象,类似于:
db = pymysql.connect(host='localhost',user='root',db='huangwei',
password='123456',port=3306,charset='utf8')
#or
db=sqlite3.connect(数据库文件)
db.cursor()的db是一个字符串,所以无法调用cursor这个方法,你要看看你的代码dbutils.py是怎样定义
您好,我是有问必答小助手,您的问题已经有小伙伴帮您解答,感谢您对有问必答的支持与关注!