在数据处理中,根据现有列的值创建或修改新列是pandas dataframe的常见操作。当需要基于多列的组合条件来决定新列的值时,开发者可能会倾向于使用列表推导(list comprehension)。然而,在使用列表推导同时迭代多列时,常常会遇到语法错误。
当尝试在列表推导中同时迭代DataFrame的多列时,直接将多个Series对象放置在for循环的in关键字之后是错误的语法。正确的做法是使用Python内置的zip函数,它能将多个可迭代对象打包成一个元组的迭代器,从而允许我们同时遍历这些对象。
错误示例回顾:
names_df['Surname'] = [ 'MISSING' if i != '' and j == '' else j for i, j in names_df['Name Entry 1'], names_df['Name Entry 2'] # 错误:不能直接用逗号分隔多个Series ]
上述代码的错误在于for i, j in names_df['Name Entry 1'], names_df['Name Entry 2']这一部分。Python的列表推导不支持直接通过逗号分隔多个Series来进行并行迭代。
正确使用zip函数:
zip函数可以将多个可迭代对象(如Pandas Series)的对应元素打包成一个个元组,然后返回一个由这些元组组成的迭代器。这样,在列表推导中就可以通过解包这些元组来同时获取多列的值。
import pandas as pd # 示例数据 data = {'Name Entry 1': ['John', '', 'Jane', 'Mike'], 'Name Entry 2': ['Doe', 'Smith', '', 'Johnson']} names_df = pd.DataFrame(data) # 使用zip函数修正列表推导 names_df['Surname'] = [ 'MISSING' if i != '' and j == '' else j for i, j in zip(names_df['Name Entry 1'], names_df['Name Entry 2']) ] print("使用zip修正后的DataFrame:") print(names_df)
输出:
使用zip修正后的DataFrame: Name Entry 1 Name Entry 2 Surname 0 John Doe Doe 1 Smith Smith 2 Jane MISSING MISSING 3 Mike Johnson Johnson
这种方法对于简单的条件判断非常简洁高效。然而,当条件逻辑变得复杂,涉及多个elif分支时,列表推导的可读性会迅速下降。
对于包含多个条件分支(类似if-elif-else结构)的场景,将逻辑封装在一个独立的函数中,并结合Pandas DataFrame的apply()方法是更推荐的做法。这种方法显著提升了代码的可读性、可维护性和扩展性。
实现步骤:
示例代码:
import pandas as pd # 示例数据 data = {'Name Entry 1': ['John', '', 'Jane', 'Mike', 'Emily'], 'Name Entry 2': ['Doe', 'Smith', '', 'Johnson', '']} names_df = pd.DataFrame(data) def determine_surname(row): """ 根据'Name Entry 1'和'Name Entry 2'的值决定'Surname'。 可以根据需要添加更多条件。 """ if row['Name Entry 1'] != '' and row['Name Entry 2'] == '': return 'MISSING' elif row['Name Entry 1'] == '' and row['Name Entry 2'] != '': return row['Name Entry 2'] # 例如:如果Entry 1为空但Entry 2不为空,则使用Entry 2 # 添加更多elif条件... else: return row['Name Entry 2'] # 默认情况 names_df['Surname_Applied'] = names_df.apply(determine_surname, axis=1) print("\n使用apply和自定义函数后的DataFrame:") print(names_df)
输出:
使用apply和自定义函数后的DataFrame: Name Entry 1 Name Entry 2 Surname_Applied 0 John Doe Doe 1 Smith Smith 2 Jane MISSING MISSING 3 Mike Johnson Johnson 4 Emily MISSING MISSING
apply()方法的优势:
在Pandas中基于多列条件创建新列时,选择合适的方法至关重要:
在处理大型数据集时,如果性能是首要考虑因素,并且条件逻辑可以通过数值操作或简单的布尔条件组合表达,可以考虑使用Pandas的向量化操作,如np.where或np.select(需要导入NumPy),它们通常比apply更快。然而,对于涉及字符串操作或复杂业务逻辑的场景,apply结合自定义函数仍然是兼顾效率与可读性的优秀选择。
以上就是Pandas DataFrame条件赋值:列表推导与apply函数的进阶使用的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 //m.sbmmt.com/ All Rights Reserved | php.cn | 湘ICP备2023035733号