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

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

基于 bin 創(chuàng)建列

基于 bin 創(chuàng)建列

狐的傳說 2021-07-23 18:19:05
我有一個數(shù)據(jù):# dtColumn1           1      2      3      4      5      6      7      8      9我想通過 bin 的最小值和最大值的平均值創(chuàng)建一個新列。# dtColumn1    Column2      1          2      2          2      3          2      4          5      5          5      6          5      7          8      8          8      9          8pd.qcut(dt['Column1'], 3)所以 column2 = (bin 的最小值 + bin 的最大值)/2。
查看完整描述

1 回答

?
慕仙森

TA貢獻1827條經驗 獲得超8個贊

GroupBy.transform與 lambda 函數(shù)Series一起使用以返回與原始大小相同的大小DataFrame:


dt['Column2'] = (dt.groupby(pd.qcut(dt['Column1'], 3))['Column1']

                   .transform(lambda x: x.max() + x.min()) / 2)

或者使用 doubletransform和addand div:


g = dt.groupby(pd.qcut(dt['Column1'], 3))

dt['Column2'] = g['Column1'].transform('max').add(g['Column1'].transform('min')).div(2)

print (dt)

   Column1  Column2

0        1      2.0

1        2      2.0

2        3      2.0

3        4      5.0

4        5      5.0

5        6      5.0

6        7      8.0

7        8      8.0

8        9      8.0

編輯:


cols = ['Column1']

for col in cols:

    dt[f'New {col}'] = (dt.groupby(pd.qcut(dt[col], 3))[col]

                       .transform(lambda x: x.max() + x.min()) / 2)

print (dt)

   Column1  New Column1

0        1          2.0

1        2          2.0

2        3          2.0

3        4          5.0

4        5          5.0

5        6          5.0

6        7          8.0

7        8          8.0

8        9          8.0


查看完整回答
反對 回復 2021-07-28
  • 1 回答
  • 0 關注
  • 170 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號

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