AttributeError: 'Mysql' object has no attribute 'conn'
时间: 2023-11-01 20:00:42 浏览: 58
AttributeError: 'Mysql' object has no attribute 'conn' 错误是由于对象Mysql缺少属性'conn'引起的。在你的代码中,你的MysqlDb类的构造函数应该是`__init__`而不是`__int__`。请在构造函数中将`__int__`更正为`__init__`,这样你就可以正确地初始化`self.conn`和`self.cur`属性了。
```python
import pymysql
class MysqlDb:
def __init__(self):
self.conn = pymysql.connect(host="192.168.253.128", user="root", password="123456", database="testcase")
self.cur = self.conn.cursor(cursor=pymysql.cursors.DictCursor)
def query(self, sql):
self.cur.execute(sql)
data = self.cur.fetchall()
return data
if __name__ == '__main__':
mydb = MysqlDb()
r = mydb.query("select * from `case`")
print(r)
```
相关问题
AttributeError: module object has no attribute load
AttributeError: module object has no attribute load 是一个常见的Python错误,通常是由于模块中不存在所需的属性或方法而引起的。这可能是由于拼写错误、导入错误或版本不兼容性等原因导致的。
如果您遇到此错误,请按照以下步骤进行排除故障:
1.检查拼写错误:请确保您正确拼写了属性或方法名称,并且没有使用任何大小写错误。
2.检查导入错误:请确保您已正确导入模块,并且模块中确实存在所需的属性或方法。
3.检查版本不兼容性:请确保您正在使用的模块版本与您的代码兼容。
以下是一个例子,演示了当模块中不存在所需的属性时,会出现AttributeError: module object has no attribute load的错误:
```python
import pandas as pd
data = pd.read_csv('data.csv')
# 上面这行代码会出现AttributeError: module object has no attribute 'read_csv'的错误,
# 因为pandas模块中不存在read_csv属性,正确的属性名称应该是read_csv()方法。
```
AttributeError: int object has no attribute int
抱歉,根据提供的引用内容,无法回答“AttributeError: int object has no attribute int”的问题。但是,根据错误信息“AttributeError: 'int' object has no attribute 'encode'”和“AttributeError: 'int' object has no attribute 'endswith'”,可以得出结论:在代码中,将整数类型的变量当作字符串类型来使用了,而整数类型没有“encode”或“endswith”等字符串类型的属性,因此会出现“AttributeError”错误。
解决这个问题的方法是,检查代码中是否有将整数类型的变量当作字符串类型来使用的情况,如果有,需要将其转换为字符串类型后再进行操作。可以使用str()函数将整数类型的变量转换为字符串类型,例如:
```python
num = 123
str_num = str(num)
```