因为java开发的习惯,想要在python开发中使用类似JavaBean的结构。
在python可以直接结合java中的编写习惯编写getter和setter方法。下方是一个示例:
class DataBean:
"""bean类"""
def __init__(self):
"""构造方法"""
self.username: str = ""
self.password: str = ""
def set_username(self, username: str):
"""设置用户名"""
self.username = username
def set_password(self, password: str):
"""设置密码"""
self.password = password
def get_username(self):
"""获取用户名"""
return self.username
def get_password(self):
""""获取密码"""
return self.password
这是结合java的习惯与python类的使用写出的getter和setter结构,当然也可以完全按照java中的写法,参考下方示例:
class DataBean:
"""bean类"""
# 用户名
username: str = ""
# 密码
password: str = ""
def set_username(self, username: str):
"""设置用户名"""
self.username = username
def set_password(self, password: str):
"""设置密码"""
self.password = password
def get_username(self):
"""获取用户名"""
return self.username
def get_password(self):
""""获取密码"""
return self.password
其实就是将构造方法中通过self定义的变量提取出来,效果是一致的。
在python内置的装饰器中,@property和@XXX.setter是针对于getter和setter方法的不二之选。
当一个方法(函数)的最终目的是返回一个值时,可以@property装饰该方法(因为java的使用习惯,我更想称之为注解),这样就可以达成getter方法。
当在一个方法的上方使用XXX.setter装饰时,代表可以直接通过类实例对象名称.变量名为其变量赋值,其中XXX代表变量名同时也是方法(函数)名称,具体可以看下方示例:
class DataBean:
"""bean类"""
# 替代setter方法
@username.setter
def username(self, username: str):
"""设置用户名"""
self.username = username
@password.setter
def password(self, password: str):
"""设置密码"""
self.password = password
# 替代getter方法
@property
def username(self):
"""获取用户名"""
return self.username
@property
def password(self):
""""获取密码"""
return self.password
# 测试
data_bean = DataBean()
# 直接赋值
date_bean.username = "123"
print(data_bean.username)