内部类的dos方法需要一个自变量,但已经给出了。 主要思想是拥有一个像模块一样的django数据库模型。 要拥有一个包含用户数据的User类,并使用同一类查询所有结果
class User:
def __init__(self, name, password):
self.name = name
self.password = sha256.encrypt(password)
def verify_password(self, psw):
return sha256.verify(self.password, psw)
def save(self):
cur.execute("INSERT INTO user (name, password) VALUES (?,?)", (self.name, self.password))
conn.commit()
class query(object):
def __init__(self):
self.data = cur.execute("SELECT * from user")
self.test = "test"
def first(self):
return self.data.fetchone()
def all(self):
return self.data.fetchall()
print(User.query.all())
我收到以下错误:
Traceback (most recent call last):
File "C:\Users\Zsolt\Desktop\api\model.py", line 34, in <module>
print(User.query.all())
TypeError: all() missing 1 required positional argument: 'self'
答案 0 :(得分:1)
对于此答案,我已将您的代码简化为更通用的代码段:
class A:
class B:
def __init__(self):
print("query the database")
def first(self):
print("return the first match only")
def all(self):
print("return all matches")
A.B.all()
在突出显示的行中,您永远不会创建B类的实例!标记的行应改为A.B().all()
,创建类型为A.B
的对象,然后在该实例上调用方法。
注意:在您的代码段中,您需要将User.query.all()
更改为User.query().all()
。