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

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

想要在 python 中執(zhí)行分組,分組數(shù)據(jù)將進(jìn)入行

想要在 python 中執(zhí)行分組,分組數(shù)據(jù)將進(jìn)入行

明月笑刀無情 2021-09-02 11:03:41
我有這樣的數(shù)據(jù):ID Value1  ABC1  BCD1  AKB2  CAB2  AIK3  KIB我想執(zhí)行一個(gè)操作,它會(huì)給我這樣的東西:ID Value1 Value2 Value31  ABC    BCD    AKB 2  CAB    AIK3  KIB我使用了 SAS,其中使用了 retain 和 by 我們過去常常得到答案。在 Python 中,我沒有任何辦法。我知道我必須使用 group by 然后一些東西。但是不知道有什么用。在 Pyspark 中使用 group by 和 collect_list 我們可以以數(shù)組格式獲取它,但我想在 Pandas 數(shù)據(jù)框中進(jìn)行
查看完整描述

3 回答

?
守著一只汪

TA貢獻(xiàn)1872條經(jīng)驗(yàn) 獲得超4個(gè)贊

使用set_index與cumcount對(duì)MultiIndex,然后通過重塑unstack:


df1 = (df.set_index(['ID',df.groupby('ID').cumcount()])['Value']

        .unstack()

        .rename(columns=lambda x: 'Value{}'.format(x + 1))

        .reset_index())

對(duì)于 python3.6+可以使用f-strings 來重命名列名稱:


df1 = (df.set_index(['ID',df.groupby('ID').cumcount()])['Value']

        .unstack()

        .rename(columns=lambda x: f'Value{x+1}')

        .reset_index())

另一個(gè)想法是由構(gòu)造函數(shù) create lists 和 new DataFrame:


s = df.groupby('ID')['Value'].apply(list)

df1 = (pd.DataFrame(s.values.tolist(), index=s.index)

       .rename(columns=lambda x: 'Value{}'.format(x + 1))

       .reset_index())

print (df1)

   ID Value1 Value2 Value3

0   1    ABC    BCD    AKB

1   2    CAB    AIK    NaN

2   3    KIB    NaN    NaN

性能:取決于行數(shù)和列的唯一值數(shù)ID:


np.random.seed(45)


a = np.sort(np.random.randint(1000, size=10000))

b = np.random.choice(list('abcde'), size=10000)


df = pd.DataFrame({'ID':a, 'Value':b})

#print (df)

In [26]: %%timeit

    ...: (df.set_index(['ID',df.groupby('ID').cumcount()])['Value']

    ...:         .unstack()

    ...:         .rename(columns=lambda x: f'Value{x+1}')

    ...:         .reset_index())

    ...: 

8.96 ms ± 628 μs per loop (mean ± std. dev. of 7 runs, 100 loops each)


In [27]: %%timeit

    ...: s = df.groupby('ID')['Value'].apply(list)

    ...: (pd.DataFrame(s.values.tolist(), index=s.index)

    ...:        .rename(columns=lambda x: 'Value{}'.format(x + 1))

    ...:        .reset_index())

    ...: 

    ...: 

105 ms ± 7.39 ms per loop (mean ± std. dev. of 7 runs, 10 loops each)


#jpp solution

In [28]: %%timeit

    ...: def group_gen(df):

    ...:     for key, x in df.groupby('ID'):

    ...:         x = x.set_index('ID').T

    ...:         x.index = pd.Index([key], name='ID')

    ...:         x.columns = [f'Value{i}' for i in range(1, x.shape[1]+1)]

    ...:         yield x

    ...: 

    ...: pd.concat(group_gen(df)).reset_index()

    ...: 


3.23 s ± 20.1 ms per loop (mean ± std. dev. of 7 runs, 1 loop each)


查看完整回答
反對(duì) 回復(fù) 2021-09-02
?
慕桂英4014372

TA貢獻(xiàn)1871條經(jīng)驗(yàn) 獲得超13個(gè)贊

groupby + concat

一種方法是迭代一個(gè)groupby對(duì)象并連接結(jié)果數(shù)據(jù)幀:


def group_gen(df):

    for key, x in df.groupby('ID'):

        x = x.set_index('ID').T

        x.index = pd.Index([key], name='ID')

        x.columns = [f'Value{i}' for i in range(1, x.shape[1]+1)]

        yield x


res = pd.concat(group_gen(df)).reset_index()


print(res)


   ID Value1 Value2 Value3

0   1    ABC    BCD    AKB

1   2    CAB    AIK    NaN

2   3    KIB    NaN    NaN


查看完整回答
反對(duì) 回復(fù) 2021-09-02
  • 3 回答
  • 0 關(guān)注
  • 173 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

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