在pandas中将两个数据框列合并为1

vip*_*per 5 python dataframe pandas

我的数据框中有2列,我需要将其合并为1个单列

Index  A             Index   B
0      A             0       NAN
1      NAN           1       D
2      B             2       NAN
3      NAN           3       E
4      C             4       NAN
Run Code Online (Sandbox Code Playgroud)

列中始终会有一个1值,我希望我的结果看起来像

0    A
1    B
2    C
3    D
4    E
Run Code Online (Sandbox Code Playgroud)

piR*_*red 6

选项1

df.stack().dropna().reset_index(drop=True)

0    A
1    D
2    B
3    E
4    C
dtype: object
Run Code Online (Sandbox Code Playgroud)

选项2 如果缺失值始终交替

df.A.combine_first(df.B)

Index
0    A
1    D
2    B
3    E
4    C
Name: A, dtype: object
Run Code Online (Sandbox Code Playgroud)

选项3 您的要求

df.A.append(df.B).dropna().reset_index(drop=True)

0    A
1    B
2    C
3    D
4    E
dtype: object
Run Code Online (Sandbox Code Playgroud)

选项4 类似于3,但列数任意

pd.concat([i for _, i in df.iteritems()]).dropna().reset_index(drop=True)

0    A
1    B
2    C
3    D
4    E
dtype: object
Run Code Online (Sandbox Code Playgroud)