gpt4 book ai didi

python - 新列作为其他列的列表,但没有 nans

转载 作者:行者123 更新时间:2023-12-04 07:43:38 25 4
gpt4 key购买 nike

基本上,我有这样的数据框:

  c1   c2    
0 a x
1 b NaN
我想要列 c像这样:
  c1   c2       c
0 a x [a, x]
1 b NaN [b]

这是我的解决方案:
import pandas as pd
import numpy as np

df = pd.DataFrame({'c1': ['a', 'b'], 'c2': ['x', np.nan]})

df['c'] = df[['c1', 'c2']].values.tolist()
df['c'] = df['c'].apply(lambda x: [i for i in x if i is not np.nan])
但我认为存在更短、更简单、更疯狂的东西。
你能帮我做一个单线吗?

最佳答案

让我们试试 stackgroupby

df['c'] = df.stack().groupby(level=0).agg(list)
list 的替代方法理解
df['c'] = [v[pd.notna(v)] for v in df.values]
  c1   c2       c
0 a x [a, x]
1 b NaN [b]

关于python - 新列作为其他列的列表,但没有 nans,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/67315017/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com