pandas shift函数基础

在使用pandas的过程中,有时会遇到shift函数,今天就一起来彻底学习下。先来看看帮助文档是怎么说的:

>>> import pandas

>>> help(pandas.dataframe.shift)

help on function shift in module pandas.core.frame:

shift(self, periods=1, freq=none, axis=0)

shift index by desired number of periods with an optional time freq

parameters

----------

periods : int

number of periods to move, can be positive or negative

freq : dateoffset, timedelta, or time rule string, optional

increment to use from the tseries module or time rule (e.g. 'eom').

see notes.

axis : {0 or 'index', 1 or 'columns'}

notes

-----

if freq is specified then the index values are shifted but the data

is not realigned. that is, use freq if you would like to extend the

index when shifting and preserve the original data.

returns

-------

shifted : dataframe

该函数主要的功能就是使数据框中的数据移动,若freq=none时,根据axis的设置,行索引数据保持不变,列索引数据可以在行上上下移动或在列上左右移动;若行索引为时间序列,则可以设置freq参数,根据periods和freq参数值组合,使行索引每次发生periods*freq偏移量滚动,列索引数据不会移动。

参数详解:

period:表示移动的幅度,可以是正数,也可以是负数,默认值是1,1就表示移动一次,注意这里移动的都是数据,而索引是不移动的,移动之后没有对应值的,就赋值为nan。

freq: dateoffset, timedelta, or time rule string,可选参数,默认值为none,只适用于时间序列,如果这个参数存在,那么会按照参数值移动时间索引,而数据值没有发生变化。

axis: {0, 1, ‘index', ‘columns'},表示移动的方向,如果是0或者'index'表示上下移动,如果是1或者'columns',则会左右移动。

先来看一下一些简单的示例:

1、非时间索引下period的设置

假设存在一个dataframe数据df:

index value1

a 0

b 1

c 2

d 3

如果执行以下代码  df.shift()  就会变成如下:

index value1

a nan

b 0

c 1

d 2

执行 df.shift(2) 就会得到:

index value1

a nan

b nan

c 0

d 1

执行 df.shift(-1) 会得到:

index value1

a 1

b 2

c 3

d nan

注意,shift移动的是整个数据,如果df有如下多列数据:

aa bb cc dd

a 0 1 2 3

b 4 5 6 7

c 8 9 10 11

d 12 13 14 15

执行 df.shift(2) 的数据为:

aa bb cc dd

a nan nan nan nan

b nan nan nan nan

c 0.0 1.0 2.0 3.0

d 4.0 5.0 6.0 7.0

如果只想移动df中的某一列数据,则需要这样操作: df['dd']= df['dd'].shift(1)

执行后的数据为:

aa bb cc dd

a 0 1 2 nan

b 4 5 6 nan

c 8 9 10 11

d 12 13 14 15

2、时间索引下freq 参数设置

假设存在如下dataframe的df:

df = pd.dataframe(np.arange(16).reshape(4,4),columns=['aa','bb','cc','dd'],index =pd.date_range('2012-06-01','2012-06-04'))

aa bb cc dd

2012-06-01 0 1 2 3

2012-06-02 4 5 6 7

2012-06-03 8 9 10 11

2012-06-04 12 13 14 15

执行 df.shift(freq=datetime.timedelta(1))  后:

aa bb cc dd

2012-06-02 0 1 2 3

2012-06-03 4 5 6 7

2012-06-04 8 9 10 11

2012-06-05 12 13 14 15

执行 df.shift(freq=datetime.timedelta(-2)) 后:

aa bb cc dd

2012-05-30 0 1 2 3

2012-05-31 4 5 6 7

2012-06-01 8 9 10 11

2012-06-02 12 13 14 15

可以看到索引直接变了。

3、axis轴向设置

df = pd.dataframe(np.arange(16).reshape(4,4),columns=['aa','bb','cc','dd'],index =['a','b','c','d'])

df

out[1]:

aa bb cc dd

a 0 1 2 3

b 4 5 6 7

c 8 9 10 11

d 12 13 14 15

#当period为正时,默认是axis = 0轴的设定,向下移动

df.shift(2)

out[2]:

aa bb cc dd

a nan nan nan nan

b nan nan nan nan

c 0.0 1.0 2.0 3.0

d 4.0 5.0 6.0 7.0

#当axis=1,沿水平方向进行移动,正数向右移,负数向左移

df.shift(2,axis = 1)

out[3]:

aa bb cc dd

a nan nan 0.0 1.0

b nan nan 4.0 5.0

c nan nan 8.0 9.0

d nan nan 12.0 13.0

#当period为负时,默认是axis = 0轴的设定,向上移动

df.shift(-1)

out[4]:

aa bb cc dd

a 4.0 5.0 6.0 7.0

b 8.0 9.0 10.0 11.0

c 12.0 13.0 14.0 15.0

d nan nan nan nan

pandas 中上下两行相减(隔行相减) -- shift函数的使用

最近使用pandas处理数据,需求是想相邻两行上下相减,查api发现shift函数,很灵活,。你也可以隔任意行相减。

p['xx_1'] = p["xx"].shift(1)

上面得到的就是xx字段向下移动一行的结果,和之前相比向下移动一行,你可以设置为任意行,也可是向上向下

p['xx'] - p["xx_1"]

这就是前后两行的差值,很方便,pandas很强大

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对萬仟网的支持。

希望与广大网友互动??

点此进行留言吧!

python中shift函数rolling_Pandas Shift函数的基础入门学习笔记相关推荐

  1. python基础入门学习笔记 (2)

    python基础入门学习笔记 2021年2月8日 1 编译器和解释器的区别 编译器/解释器:高级语言与机器之间的翻译官 2 值传递: print "a = ",a print &q ...

  2. Python零基础入门学习笔记(一)

    Python 基础入门学习 欢迎访问博客:Python学习笔记 基本语句 基本数据类型 函数 文件操作 面向对象 异常 模块 一.基本语句 注释: # 单行注释 """多 ...

  3. python必背入门代码-Python零基础入门学习笔记(一)

    字符串可以用单引号.双引号.三引号括起来,字符串为不可变类型. python中每个字符串自带下标和索引,可用 str[x] 来精确访问字符串 str 中的某个字符 切片: 指对 字符串.列表.元组 进 ...

  4. 【小甲鱼】python零基础入门学习笔记 03讲~43讲

    本篇基于[莫烦]python基础教程,属于查漏补缺 建议学习顺序 小甲鱼->莫烦numpy&pandas 目录 第003讲 插曲之变量和字符串 课堂笔记 变量 变量 需要注意的地方 字符 ...

  5. Python入门第四天——[小甲鱼]零基础入门学习Python

    36~040类和对象 是数据和函数的一种封装形式,对象 = 属性+方法(对象是某个类的一个实例,创建类的一个实例,用这个实例表示类就叫对象) 类的定义: class Turtle: #Python中类 ...

  6. Python基础入门学习笔记

    一. print()函数与变量 print()函数 前提:全部用英文输入法输入!!!!! print(): 括号里加'',也可用双引号"",输出字符串,如print('1+1')输 ...

  7. 鱼c工作室python课件_鱼C工作室《零基础入门学习Python》 学习过程笔记【011列表类的方法】...

    011. 如何交换列表中两个位置的值?(用从前那种交换两个变量的值的方法即可) >>> b=[0,1,2] >>> b[1] 1 >>> b[2] ...

  8. 零基础学python书籍-清华大学出版社-图书详情-《零基础入门学习Python》

    前言 Life is short. You need Python. --Bruce Eckel 上边这句话是Python社区的名言,翻译过来就是"人生苦短,我用Python". ...

  9. python语言语块句的标记_NLTK基础教程学习笔记(十一)

    语块分解例子: from nltk.chunk.regexp import * import nltk test_sent="The prime minister announced he ...

最新文章

  1. 用EC5/EC6自定义class的区别及用法 -- Phaser3网页游戏框架
  2. buu 萌萌哒的八戒
  3. JavaScript 面向对象编程实现
  4. 十二、深入Java的循环语句
  5. hdu 3068 最长回文【manacher】(模板题)
  6. alibab仓库 idea_01.微服务架构编码、构建
  7. python判断是否为完全数_Python识别完美数
  8. 计算机三级之嵌入式系统学习笔记5
  9. Tools:Android studio 使用
  10. 合并传闻是真是假?ofo摩拜之争是否继续?(产品)
  11. 春考计算机组装与维护,计算机组装与维护教程(高职高专计算机系列)
  12. 413 Arithmetic Slices
  13. Camera 驱动 读取摄像头ID失败问题、低温下Camera打开花屏或者读不到id、概率性读取不到id
  14. win服务器系统更新失败怎么办,win10系统更新失败怎么办
  15. 体感互动虚拟试衣系统
  16. 机器视觉系列(一)——概述
  17. 服务器是干什么用的?
  18. fmri学习笔记|SPM 代码 循环
  19. C#练习题答案: 产品和LCMS之间的差异总和【难度:1级】--景越C#经典编程题库,1000道C#基础练习题等你来挑战
  20. ubuntu下载谷歌云盘大文件

热门文章

  1. sql server查询某一字段不重复的数据_初识数据库
  2. 下列不是unix linux,下列软件中,不是操作系统的是______。A) LinuxB) UNIXC) MS-DOSD) MS-OfficeA.B.C.D._考题宝...
  3. java string is empty_从源码分析java.lang.String.isEmpty()
  4. asp python 定时任务_Ubuntu使用crontab定时执行python脚本
  5. cp和scp复制命令
  6. SSM框架笔记14:Spring MVC表单验证
  7. 【codevs3153】【BZOJ3895】取石子游戏,博弈论之记忆化搜索
  8. java shiro jwt_Springboot实现Shiro整合JWT的示例代码
  9. 【英语学习】【Daily English】U15 Culture L02 For a second I wanted to go home
  10. python chromedriver_Linux下搭建Python3.7+Selenium+Chrome+Chromedriver