在 Python 中从字典创建类实例
Python 中从字典创建类实例:
-
从类的
__init__()
方法中获取字典。 - 遍历字典的项目。
-
使用
setattr
方法将每个键值对分配为实例属性。
class Employee():
def __init__(self, dictionary):
for key, value in dictionary.items():
setattr(self, key, value)
my_dict = {'name': 'jiyik', 'salary': 100, 'language': 'Python'}
emp = Employee(my_dict)
print(emp.name) # 👉️ jiyik
print(emp.salary) # 👉️ 100
print(emp.language) # 👉️ Python
__init__()
方法采用字典并将其键值对设置为实例属性。
我们使用 for
循环遍历字典的项目。
dict.items
方法返回字典项((键,值)对)的新视图。
my_dict = {'id': 1, 'name': 'Jiyik'}
print(my_dict.items()) # 👉️ dict_items([('id', 1), ('name', 'Jiyik')])
在每次迭代中,我们使用 setattr()
函数将每个键值对设置为实例的一个属性。
setattr()
函数将对象、属性名称和值作为参数。
如果我们的字典包含带空格的键,请使用 str.replace()
方法将每个空格替换为下划线。
class Employee():
def __init__(self, dictionary):
for key, value in dictionary.items():
setattr(self, str(key).replace(' ', '_'), value)
my_dict = {'first name': 'jiyik', 'salary': 100, 'language': 'Python'}
emp = Employee(my_dict)
print(emp.first_name) # 👉️ jiyik
print(emp.salary) # 👉️ 100
print(emp.language) # 👉️ Python
名字键包含一个空格,因此我们使用 str.replace()
方法将字典键中的任何空格替换为下划线。
如果我们在尝试访问每个实例的属性时遇到 linting
错误,例如 “‘Employee’类型的实例没有‘X’成员”,将属性初始化为 None。
class Employee():
def __init__(self, dictionary):
self.name = None
self.salary = None
self.language = None
for key, value in dictionary.items():
setattr(self, str(key).replace(' ', '_'), value)
my_dict = {'name': 'jiyik', 'salary': 100, 'language': 'Python'}
emp = Employee(my_dict)
print(emp.name) # 👉️ jiyik
print(emp.salary) # 👉️ 100
print(emp.language) # 👉️ Python
我们将所有属性初始化为 None,因此我们可以访问每个实例上的属性而不会出现 linting 错误。
要考虑的另一种方法是在 __init__()
方法中定义属性,并在实例化类时解压缩字典的键值对。
class Employee():
def __init__(self, name, salary, language):
self.name = name
self.salary = salary
self.language = language
my_dict = {'name': 'jiyik', 'salary': 100, 'language': 'Python'}
emp = Employee(**my_dict)
print(emp.name) # 👉️ jiyik
print(emp.salary) # 👉️ 100
print(emp.language) # 👉️ Python
我们在实例化类的时候使用了**
运算符来解包字典的键值对。
我们可以想象字典的键值对作为关键字参数传递给类,例如 Employee(name='bobbyhadz', salary=100)
。
相关文章
Python pandas.pivot_table() 函数
发布时间:2024/04/24 浏览次数:82 分类:Python
-
Python Pandas pivot_table()函数通过对数据进行汇总,避免了数据的重复。
在 Python 中将 Pandas 系列的日期时间转换为字符串
发布时间:2024/04/24 浏览次数:894 分类:Python
-
了解如何在 Python 中将 Pandas 系列日期时间转换为字符串
在 Python Pandas 中使用 str.split 将字符串拆分为两个列表列
发布时间:2024/04/24 浏览次数:1124 分类:Python
-
本教程介绍如何使用 pandas str.split() 函数将字符串拆分为两个列表列。
在 Pandas 中将 Timedelta 转换为 Int
发布时间:2024/04/23 浏览次数:231 分类:Python
-
可以使用 Pandas 中的 dt 属性将 timedelta 转换为整数。
Python 中的 Pandas 插入方法
发布时间:2024/04/23 浏览次数:112 分类:Python
-
本教程介绍了如何在 Pandas DataFrame 中使用 insert 方法在 DataFrame 中插入一列。
使用 Python 将 Pandas DataFrame 保存为 HTML
发布时间:2024/04/21 浏览次数:106 分类:Python
-
本教程演示如何将 Pandas DataFrame 转换为 Python 中的 HTML 表格。
如何将 Python 字典转换为 Pandas DataFrame
发布时间:2024/04/20 浏览次数:73 分类:Python
-
本教程演示如何将 python 字典转换为 Pandas DataFrame,例如使用 Pandas DataFrame 构造函数或 from_dict 方法。
如何在 Pandas 中将 DataFrame 列转换为日期时间
发布时间:2024/04/20 浏览次数:101 分类:Python
-
本文介绍如何将 Pandas DataFrame 列转换为 Python 日期时间。