第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

將具有混合整數(shù)的列拆分為多列的元組

將具有混合整數(shù)的列拆分為多列的元組

森林海 2022-11-29 14:50:32
我有一個DF   a     b   0  (0,1) 11  1     (1,2)2  2     3所需的輸出是:    w  x  y  z0   0  1  1  01   1  0  1  22   2  0  3  3問題是,元組可以有多個不同的長度。以下 tolist() 僅適用于長度為 2 的元組,不適用于混合列。df[['w', 'x']]=pd.DataFrame(df['a'].tolist(), index=df.index) 有任何想法嗎?提前致謝。
查看完整描述

2 回答

?
慕的地10843

TA貢獻1785條經(jīng)驗 獲得超8個贊

想法是添加元組 if 標量然后創(chuàng)建新列:


def f(col):

    return pd.DataFrame([x if isinstance(x, tuple) else (x, ) 

                        for x in col]).fillna(0).astype(int)


df[['w', 'x']]=df.pop('a').pipe(f)

df[['y', 'z']]=df.pop('b').pipe(f)


print (df)

   w  x  y  z

0  0  1  1  0

1  1  0  1  2

2  2  0  3  0

更通用的解決方案concat:


dfs= [pd.DataFrame([x if isinstance(x, tuple) else (x, ) for x in df.pop(c)], 

                    index=df.index) for c in df.columns]


df = pd.concat(dfs, axis=1, ignore_index=True).fillna(0).astype(int)


print (df)

   0  1  2  3

0  0  1  1  0

1  1  0  1  2

2  2  0  3  0


查看完整回答
反對 回復(fù) 2022-11-29
?
大話西游666

TA貢獻1817條經(jīng)驗 獲得超14個贊

您可以轉(zhuǎn)換為,然后str轉(zhuǎn)換strip為()split,


>>> df[['w', 'x']] = pd.DataFrame(df.pop('a')

                                    .astype(str)

                                    .str.strip('(/)')

                                    .str.split(',')

                                    .tolist()).fillna(0).astype(int)


>>> df[['y', 'z']] = pd.DataFrame(df.pop('b')

                                    .astype(str)

                                    .str.strip('(/)')

                                    .str.split(',')

                                    .tolist()).fillna(0).astype(int)


>>> df


   w  x  y  z

0  0  1  1  0

1  1  0  1  2

2  2  0  3  0


查看完整回答
反對 回復(fù) 2022-11-29
  • 2 回答
  • 0 關(guān)注
  • 105 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學習伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號