亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

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

每當下一行與上一行不同時就增加一個值

每當下一行與上一行不同時就增加一個值

慕標琳琳 2023-07-27 09:50:43
我有這個 df :namestr_astr_astr_astr_bstr_bstr_cstr_cname在我得到的列中str,我想創建另一個名為number第一行 0 的列,然后每次前一個名稱與下一個名稱不同時,它都會在前一個數字上添加+1。預期結果是:name  numberstr_a 0str_a 0str_a 0str_b 1str_b 1 str_c 2 str_c 2有沒有辦法在沒有循環的情況下做到這一點?
查看完整描述

1 回答

?
哈士奇WWW

TA貢獻1799條經驗 獲得超6個贊

讓我們嘗試一下shift,cumsum請注意,您可以檢查df['name'].factorize()[0] ,但是,如果名稱重復但不總是連續連續,factorize則不起作用


df['name'].ne(df['name'].shift()).cumsum()-1

Out[10]: 

0    0

1    0

2    0

3    1

4    1

5    2

6    2

Name: name, dtype: int32


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

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號