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

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

我如何傳遞 : 作為 python 中的函數(shù)參數(shù)?

我如何傳遞 : 作為 python 中的函數(shù)參數(shù)?

素胚勾勒不出你 2021-09-11 19:34:12
我正在使用 python3 和 pandas,我想:作為函數(shù)參數(shù)傳遞,以聲明傳遞給df.loc.例如,假設我有一個像這樣填充 na 值的函數(shù):def fill_na_w_value(df, rows, columns, fill):    for col in columns:        df.loc[rows, columns].fillna(            fill,            inplace=True        )有時我可能不想將其應用于某些行,而是將其應用于所有行,在 Pandas 中,這是通過訪問df.loc[:, col]如果我從一個函數(shù)調(diào)用它,它會喜歡fill_na_w_value(df, :, ['col1'], 0)但是上面會給我一個語法錯誤,因為:; 如何將其作為函數(shù)參數(shù)傳遞?
查看完整描述

1 回答

?
達令說

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

使用slice(None)來表示:。請注意,您可以使用pipe通過函數(shù)傳遞數(shù)據(jù)框,并loc接受用于行和索引過濾的列表:


df = pd.DataFrame({'col1': [1, 2, np.nan, 4, 5, np.nan, 7, 8, np.nan]})


def fill_na_w_value(df, row_slicer, columns, value):

    df.loc[row_slicer, columns] = df.loc[row_slicer, columns].fillna(value)

    return df


df1 = df.pipe(fill_na_w_value, slice(None), ['col1'], 0)


print(df1)


   col1

0   1.0

1   2.0

2   0.0

3   4.0

4   5.0

5   0.0

6   7.0

7   8.0

8   0.0

這是一個使用 alist而不是slice對象的示例:


df2 = df.pipe(fill_na_w_value, [2, 5], ['col1'], 0)


print(df2)


   col1

0   1.0

1   2.0

2   0.0

3   4.0

4   5.0

5   0.0

6   7.0

7   8.0

8   NaN


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

添加回答

舉報

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號

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