
在数据分析工作中,我们经常会遇到需要根据dataframe中某个分组(例如按col1分组)的特定条件来生成新列的场景。具体来说,如果一个分组内存在某个特定值(例如col2列中包含'y'),那么该分组下的所有行在新列中都应填充一个特定的值(例如col3列中与'y'对应的那个值);如果分组内不存在该特定值,则新列应填充该行自身的col3值。
考虑以下原始数据表:
| index | Col1 | Col2 | Col3 |
|---|---|---|---|
| 0 | 1 | X | ABC |
| 1 | 1 | Y | XX |
| 2 | 1 | X | QW |
| 3 | 2 | X | VB |
| 4 | 2 | X | AY |
| 5 | 3 | X | MM |
| 6 | 3 | X | YY |
| 7 | 3 | Y | XX |
我们的目标是生成一个New_Col,其逻辑如下:
最终期望的输出结果如下:
| Col1 | Col2 | Col3 | New_Col |
|---|---|---|---|
| 1 | X | ABC | XX |
| 1 | Y | XX | XX |
| 1 | X | QW | XX |
| 2 | X | VB | VB |
| 2 | X | AY | AY |
| 3 | X | MM | XX |
| 3 | X | YY | XX |
| 3 | Y | XX | XX |
Pandas提供了一套强大的工具集来解决这类问题。我们可以通过巧妙地组合mask、groupby().transform('first')和fillna来实现上述逻辑。
首先,我们创建示例DataFrame:
import pandas as pd
import numpy as np
data = {
'Col1': [1, 1, 1, 2, 2, 3, 3, 3],
'Col2': ['X', 'Y', 'X', 'X', 'X', 'X', 'X', 'Y'],
'Col3': ['ABC', 'XX', 'QW', 'VB', 'AY', 'MM', 'YY', 'XX']
}
df = pd.DataFrame(data)
print("原始DataFrame:")
print(df)输出:
原始DataFrame: Col1 Col2 Col3 0 1 X ABC 1 1 Y XX 2 1 X QW 3 2 X VB 4 2 X AY 5 3 X MM 6 3 X YY 7 3 Y XX
我们将通过以下三个主要步骤来构建New_Col:
首先,我们创建一个Series,其中只有Col2为'Y'的行保留其对应的Col3值,其他行的值则被替换为NaN。mask函数在条件为True时替换值,所以我们使用df['Col2'] != 'Y'作为条件。
# 步骤一:隐藏非目标值
masked_col3 = df['Col3'].mask(df['Col2'] != 'Y')
print("\n步骤一:隐藏非'Y'对应的Col3值")
print(masked_col3)输出:
步骤一:隐藏非'Y'对应的Col3值 0 NaN 1 XX 2 NaN 3 NaN 4 NaN 5 NaN 6 NaN 7 XX Name: Col3, dtype: object
此时,我们得到了一个Series,其中只有那些我们感兴趣的(Col2为'Y')Col3值被保留,其余为NaN。
接下来,我们根据Col1进行分组,并使用transform('first')将每个组中的第一个非NaN值(如果有的话)传播到该组的所有行。transform操作会返回一个与原始DataFrame长度相同的Series。
# 步骤二:按Col1分组,传播第一个非空值
grouped_propagated = masked_col3.groupby(df['Col1']).transform('first')
print("\n步骤二:按Col1分组,传播第一个非空值")
print(grouped_propagated)输出:
步骤二:按Col1分组,传播第一个非空值 0 XX 1 XX 2 XX 3 None 4 None 5 XX 6 XX 7 XX Name: Col3, dtype: object
观察输出:
最后,对于那些在步骤二中仍为NaN(或None)的行(即原始分组中不包含'Y'的情况),我们使用原始的Col3值进行填充。
# 步骤三:填充剩余的缺失值
final_new_col = grouped_propagated.fillna(df['Col3'])
print("\n步骤三:填充剩余的缺失值")
print(final_new_col)输出:
步骤三:填充剩余的缺失值 0 XX 1 XX 2 XX 3 VB 4 AY 5 XX 6 XX 7 XX Name: Col3, dtype: object
至此,我们得到了符合要求的新列New_Col。
将上述步骤整合到一行代码中,我们可以直接创建New_Col:
df['New_Col'] = (df['Col3'].mask(df['Col2'] != 'Y')
.groupby(df['Col1'])
.transform('first')
.fillna(df['Col3']))
print("\n最终DataFrame:")
print(df)输出:
最终DataFrame: Col1 Col2 Col3 New_Col 0 1 X ABC XX 1 1 Y XX XX 2 1 X QW XX 3 2 X VB VB 4 2 X AY AY 5 3 X MM XX 6 3 X YY XX 7 3 Y XX XX
通过掌握这种组合mask、groupby().transform()和fillna()的方法,数据分析师可以高效地解决Pandas中涉及条件分组填充新列的复杂问题,从而提高数据处理的灵活性和效率。
以上就是使用Pandas进行条件分组后填充新列:高级技巧解析的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号