python對列進行平移變換的方法(shift)
在進行數(shù)據(jù)操作時, 經(jīng)常會碰到基于同一列進行錯位相加減的操作, 即對某一列進行向上或向下平移(shift).
往常, 我們都會使用循環(huán)進行操作, 但經(jīng)過查閱相關資料, 發(fā)現(xiàn)結合pandas里的groupby和shift兩個函數(shù)就能輕松實現(xiàn)上述要求.
#創(chuàng)建樣例數(shù)據(jù)
temp = pd.DataFrame({'id':[1,1,1,2,2,3],'value':[1,2,3,4,5,6]});temp
Out[1]: id value 0 1 1 1 1 2 2 1 3 3 2 4 4 2 5 5 3 6
temp['value_shift'] = temp.groupby('id')['value'].shift(1);temp
Out[180]:
id value value_shift
0 1 1 NaN
1 1 2 1.0
2 1 3 2.0
3 2 4 NaN
4 2 5 4.0
5 3 6 NaN
temp['value_shift_1'] = temp.groupby('id')['value'].shift(-1);temp
Out[181]:
id value value_shift value_shift_1
0 1 1 NaN 2.0
1 1 2 1.0 3.0
2 1 3 2.0 NaN
3 2 4 NaN 5.0
4 2 5 4.0 NaN
5 3 6 NaN NaN
通過shift函數(shù)里面的值來控制向前還是向后偏移, 缺少的值會填充NaN.
groupby函數(shù)里的參數(shù)控制基于什么字段進行shift.
官方文檔 這里是以index為基準.
以上這篇python對列進行平移變換的方法(shift)就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
Python3 Tkinter選擇路徑功能的實現(xiàn)方法
今天小編就為大家分享一篇Python3 Tkinter選擇路徑功能的實現(xiàn)方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-06-06
python 實現(xiàn)在一張圖中繪制一個小的子圖方法
今天小編就為大家分享一篇python 實現(xiàn)在一張圖中繪制一個小的子圖方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-07-07
基于django micro搭建網(wǎng)站實現(xiàn)加水印功能
這篇文章主要介紹了基于django micro搭建網(wǎng)站實現(xiàn)加水印功能,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-05-05

