pandas DataFrame运算的实现

作者:「已注销」 时间:2021-06-02 21:08:22 

1 算术运算

add(other)

比如进行数学运算加上具体的一个数字


data['open'].add(1)

2018-02-27 24.53
2018-02-26 23.80
2018-02-23 23.88
2018-02-22 23.25
2018-02-14 22.49

sub(other)

2 逻辑运算

2.1 逻辑运算符号

例如筛选data[“open”] > 23的日期数据

data[“open”] > 23返回逻辑结果


data["open"] > 23

2018-02-27  True
2018-02-26 False
2018-02-23 False
2018-02-22 False
2018-02-14 False

# 逻辑判断的结果可以作为筛选的依据
data[data["open"] > 23].head()

pandas DataFrame运算的实现

完成多个逻辑判断,


data[(data["open"] > 23) & (data["open"] < 24)].head()

pandas DataFrame运算的实现

2.2 逻辑运算函数

query(expr)

expr:查询字符串

通过query使得刚才的过程更加方便简单


# 以字符串形式
data.query("open<24 & open>23").head()

isin(values)
例如判断'open'是否为23.53和23.85


# 可以指定值进行一个判断,从而进行筛选操作
data[data["open"].isin([23.53, 23.85])]

pandas DataFrame运算的实现

3 统计运算

3.1 describe

综合分析: 能够直接得出很多统计结果,count, mean, std, min, max 等


# 计算平均值、标准差、最大值、最小值
data.describe()

pandas DataFrame运算的实现

3.2 统计函数

Numpy当中已经详细介绍,在这里我们演示min(最小值), max(最大值), mean(平均值), median(中位数), var(方差), std(标准差),mode(众数)结果:

pandas DataFrame运算的实现

对于单个函数去进行统计的时候,坐标轴还是按照默认列“columns” (axis=0, default),如果要对行“index” 需要指定(axis=1)

max()、min()


# 使用统计函数:0 代表列求结果, 1 代表行求统计结果
data.max(0)

open     34.99
high     36.35
close     35.21
low     34.01
volume    501915.41
price_change   3.03
p_change    10.03
turnover    12.56
my_price_change   3.41
dtype: float64

std()、var()


# 方差
data.var(0)

open    1.545255e+01
high    1.662665e+01
close    1.554572e+01
low    1.437902e+01
volume    5.458124e+09
price_change  8.072595e-01
p_change   1.664394e+01
turnover   4.323800e+00
my_price_change 6.409037e-01
dtype: float64

# 标准差
data.std(0)

open     3.930973
high     4.077578
close     3.942806
low     3.791968
volume    73879.119354
price_change   0.898476
p_change    4.079698
turnover    2.079375
my_price_change  0.800565
dtype: float64

median():中位数

中位数为将数据从小到大排列,在最中间的那个数为中位数。如果没有中间数,取中间两个数的平均值。


df = pd.DataFrame({'COL1' : [2,3,4,5,4,2],
    'COL2' : [0,1,2,3,4,2]})

df.median()

COL1 3.5
COL2 2.0
dtype: float64

idxmax()、idxmin()


# 求出最大值的位置
data.idxmax(axis=0)

open    2015-06-15
high    2015-06-10
close    2015-06-12
low    2015-06-12
volume    2017-10-26
price_change  2015-06-09
p_change   2015-08-28
turnover   2017-10-26
my_price_change 2015-07-10
dtype: object

# 求出最小值的位置
data.idxmin(axis=0)

open    2015-03-02
high    2015-03-02
close    2015-09-02
low    2015-03-02
volume    2016-07-06
price_change  2015-06-15
p_change   2015-09-01
turnover   2016-07-06
my_price_change 2015-06-15
dtype: object

3.3 累计统计函数

pandas DataFrame运算的实现

那么这些累计统计函数怎么用?

pandas DataFrame运算的实现

以上这些函数可以对series和dataframe操作

这里我们按照时间的从前往后来进行累计

排序


# 排序之后,进行累计求和
data = data.sort_index()

对p_change进行求和


stock_rise = data['p_change']
# plot方法集成了前面直方图、条形图、饼图、折线图
stock_rise.cumsum()

2015-03-02  2.62
2015-03-03  4.06
2015-03-04  5.63
2015-03-05  7.65
2015-03-06  16.16
2015-03-09  16.37
2015-03-10  18.75
2015-03-11  16.36
2015-03-12  15.03
2015-03-13  17.58
2015-03-16  20.34
2015-03-17  22.42
2015-03-18  23.28
2015-03-19  23.74
2015-03-20  23.48
2015-03-23  23.74

那么如何让这个连续求和的结果更好的显示呢?

pandas DataFrame运算的实现

如果要使用plot函数,需要导入matplotlib.


import matplotlib.pyplot as plt
# plot显示图形
stock_rise.cumsum().plot()
# 需要调用show,才能显示出结果
plt.show()

关于plot,稍后会介绍API的选择

4 自定义运算

apply(func, axis=0)

  • func:自定义函数

  • axis=0:默认是列,axis=1为行进行运算

定义一个对列,最大值-最小值的函数


data[['open', 'close']].apply(lambda x: x.max() - x.min(), axis=0)

open  22.74
close 22.85
dtype: float64

来源:https://blog.csdn.net/Jack_yun_feng/article/details/99644552

标签:pandas,DataFrame,运算
0
投稿

猜你喜欢

  • Go 值传递与引用传递的方法

    2023-06-25 03:11:11
  • PHP substr()函数参数解释及用法讲解

    2023-11-24 11:47:56
  • ajax xmlhttp getResponseHeader实例教程

    2009-02-04 10:46:00
  • 在PHP中读取和写入WORD文档的代码

    2023-09-28 02:30:22
  • js 可选链操作符的使用

    2023-08-18 16:04:57
  • Python快速排序算法实例分析

    2021-10-23 09:14:37
  • python实现超市管理系统(后台管理)

    2022-08-17 06:50:22
  • 对django layer弹窗组件的使用详解

    2021-09-08 00:09:38
  • Python os库常用操作代码汇总

    2021-04-17 04:07:51
  • 价值3亿美元的按钮[译]

    2009-03-18 19:39:00
  • 如何列出SQL数据库中的存储过程?

    2010-01-12 19:58:00
  • javascript操作ASP.NET服务器控件

    2023-07-21 15:09:26
  • 利用python在大量数据文件下删除某一行的例子

    2023-08-24 09:15:22
  • Python百度指数获取脚本下载并保存

    2023-01-05 23:47:44
  • python列表推导式 经典代码

    2021-02-28 09:26:00
  • sql2005与sql200数据导入导出

    2009-03-13 13:16:00
  • Python解析多帧dicom数据详解

    2022-08-13 21:16:13
  • python实现得到一个给定类的虚函数

    2022-03-27 19:31:11
  • Python中Dataframe元素为不定长list时的拆分分组

    2023-11-08 04:16:30
  • Oracle PL/SQL语言入门基础

    2010-07-20 13:28:00
  • asp之家 网络编程 m.aspxhome.com