pandas

作者: celusing | 来源:发表于2021-06-17 14:23 被阅读0次

参考:https://geek-docs.com/pandas

一.pandas数据处理简介

1.简介

pandas:是基于:实现的python的一个数据分析包。名字来源:面板数据(panel data)和python数据分析(data analysis)
注意:
DataFrame是一个二维表格。0轴:跨行(down), 1轴:跨列(across)

  • 使用0值:表示沿着每一列或者行标签(行索引值),向下执行方法
  • 使用1值:表示沿着每一行或者列标签(列索引值),横向执行对应的方法

2.数据结构简介

  • Series:一维数组,与Numpy中一维array类似。二者与python基本的数据结构list也很接近。
  • Time-Series:以时间为索引的Series
  • DataFrame:二维的表格形数据结构。可以理解为:Series的容器
  • Panel:三维数组,可以理解为DataFrame的容器


    image.png

    1.series构造函数:


    image.png
    2.series属性和方法:
    image.png

    3.DataFrame构造函数


    image.png
    4.DataFrame属性和方法
    image.png
    5.pandas描述性统计
    image.png
    6.pandas函数应用
    image.png
    7.迭代

    7.1 对象直接进行迭代
    7.2 其他迭代


    image.png
    itertuples()方法将DataFrame中的每一行返回一个产生一个命名元组的迭代器。元组的第一个元素:是行的相应的索引值。而剩余的值是行值。

二.pandas实例

1.数据选择和赋值

1.排序

  • 按轴排序:df.sort_index(axis=1, ascending=False),表示:按照列索引值(axis=1),进行降序排列
  • 按值排序:df.sort_values(by='B')
    2.选择数据
    1)获取
  • 选择一列,产生一个‘Series’:df['A'] or df.A
  • 对行进行切片:df[0:3]
    2)按标签选择(loc)
  • 通过标签获取一行数据:df.loc[dates[0]]
  • 通过标签在多个轴上选择数据:df.loc[:, ['A', 'B']]
  • 通过标签同时在两个轴上切片:df.loc['20130102:20130104', ['A', 'B']]
    3)按位置选择(iloc)
  • 通过传递整数的位置选择:df.iloc[3]
  • 通过整数切片:df.iloc[3:5, 0:2]. PS:最后一个不包括(左闭右开)
  • 通过传递整数列表按位置切片:df.iloc[[1,2,4], [0,2]]
  • 整行切片:df.iloc[1:3]
  • 整列切片:df.iloc[:, 1:3]
  • 获取某个具体值:df.iloc[1, 1]
  • 快速访问标量:df.iat[1, 1]
    4)布尔索引
  • 使用单个列的值来选择数据:df[df.A > 0], 所有:df[]行索引, 行条件:df.A > 0
  • 从满足布尔条件的DataFrame中选择值:df[df > 0], 备注: < 0的值都变成了nan
  • 使用isin()过滤:df[df['E'].isin(['two', 'four'])]
    5)赋值(at和iat)
  • 添加新列将自动根据索引对其数据:df['F'] = 1
  • 通过标签赋值:df.at[datas[0], 'A'] = 0
  • 通过位置赋值:df.iat[0, 1] = 0
  • 使用Numpy数组赋值:df.loc[:, 'D'] = np.array([5]*len(df))
  • 带where条件的赋值操作:df2[df2 > 0] = -df2

三.pandas数据处理

1.GroupBy:分组合并

image.png

1)过程和原理
GroupBy操作由三个阶段组成:

  • 分组:将数据分成多个组。分组标准:通常与索引或某一列具体元素有关
  • 用函数处理:用函数处理每一个分组,为每组数组生成一个单一的值
  • 合并:把来自每一组的结果汇集到一起,合并成一个新对象
    2)实例:用列元素,作为键进行分组
  • group=df['price1'].groupby(df['color']), 得到的对象:GroupBy对象
    也可以写成:group=df.groupby(df['color']).price1 or group = df.groupby(df['color'])['price1']
    应该是:groupby的计算优先等级比较高
  • group.groups:查看分组情况
  • group.mean():对每个分组应用mean函数
  • group.sum():对每个分组应用sum函数
    3)等级分组:可以使用多列,多个键进行等级分组
  • group = df['price1'].groupby([df['color'], df['object']]), 先按照color进行分组,然后再对每一组按照object进行分组
  • group.sum():最小分组,进行求和

2.merge():合并

把两个DF按照一定方式合并成一个DF

3.concat:拼接

1)concatenate()函数
numpy的concatenate()函数就是用于数组的拼接擦欧总
2)concat()函数
pandas库以及它的Series和DataFrame等数据结构实现了带编号的索引,Pandas的concat()函数实现了按索引拼接的功能
例子:

#默认axis=0
ser1 = pd.Series(np.random.rand(4), index=[1,2,3,4]), 
ser2 = pd.Series(np.random.rand(4), index=[5,6,7,8])
print(pd.concat([ser1, ser2]))

#按照axis=1
ser1 = pd.Series(np.random.rand(4), index=[1,2,3,4])
ser2 = pd.Series(np.random.rand(4), index=[5,6,7,8])
print(pd.concat([ser1, ser2], axis=1))

#内连接操作
ser1 = pd.Series(np.random.rand(4), index=[1,2,3,4])
ser2 = pd.Series(np.random.rand(4), index=[5,6,7,8])
df = pd.concat([ser1, ser2], axis=1)
print(df)
print('--------')
print(pd.concat([ser1, df], axis=1, join='inner'))
image.png

concat():默认按照axis=0这条轴进行拼接数据,并返回Series对象。如果指定axis=1, 返回的结果是DataFrame对象


image.png

concat():默认是外连结操作,把join选项设置为inner,可以执行内连接操作。


image.png
3)等级索引
假如我们想用于拼接的轴上创建等级索引,可以借助keys选项来完成,如下所示:
#axis=0方向,建立额外索引
import pandas as pd
import numpy as np

ser1 = pd.Series(np.random.rand(4), index=[1,2,3,4])
ser2 = pd.Series(np.random.rand(4), index=[5,6,7,8])
print(pd.concat([ser1, ser2], keys=[1,2]))

#axis=1方向,建立索引
ser1 = pd.Series(np.random.rand(4), index=[1,2,3,4])
ser2 = pd.Series(np.random.rand(4), index=[5,6,7,8])
print(pd.concat([ser1, ser2], axis=1,keys=[1,2]))
image.png
image.png

4)DataFrame对象的拼接

  • pd.concat([frame1, frame2])
  • pd.concat([frame1, frame2], axis=1)

4.删除数据:

  • drop():返回不包含已删除索引及其元素的新对象
  • del:删除数据列
  • drop_duplicateds():从DataFrame对象中删除所有重复的行,返回删除重复行后的DataFrame对象

1)删除Series对象数据

  • drop:ser.drop('yelow') or ser.drop(['blue', 'white'])
    2)删除DataFrame对象数据
  • 删除行:frame.drop(['blue', 'yellow'])
  • 删除列:frame.drop(['pen', 'pencil'], axis=1)。axis=1,表示跨列的方向,也就是横向的方向。找pen和pencil索引并删除
  • del:删除列的另一种方式 del frame['ball']
  • 删除重复行:
    duplicated():函数可以用力啊检测重复的行,返回元素为bool的Series对象,每个元素对应一行。如果该行与前面行重复,则为True
    drop_duplicated():实现了删除功能,该函数返回删除重复行后的DataFrame对象

5.旋转数据

通常,按行或列调整元素并不总能满足目标,有时,需要按照行重新调整列或者按照列重新调整行的元素
1)DataFrame的转置

  • df.T
    2)按等级索引旋转
    前面讲过,DataFrame对象支持等级索引。利用这一点,可以还从i想你调整DataFrame对象中国呢数据,轴向旋转有两个基本操作:
  • 入栈(Stacking):旋转数据结构,把列旋转为行
  • 出栈(unStacking):把行旋转为列
import pandas as pd
import numpy as np
# df对象应用stack函数,会把列转变为行,从而得到一个Series对象
dframe = pd.DataFrame(np.arange(9).reshape(3,3),
                      index=['white', 'black', 'red'],
                      columns=['ball', 'pen', 'pencil'])
print(dframe)
print('------------')
print(dframe.stack())

#在这个具有登记索引结构的Series对象上执行unstack()操作,可以重建之前的DataFrame对象,从而可以以数据透视表的形式来展示Series对象中的等级索引结构
dframe = pd.DataFrame(np.arange(9).reshape(3,3),
                      index=['white', 'black', 'red'],
                      columns=['ball', 'pen', 'pencil'])
ser = dframe.stack()
print(ser.unstack())

#出栈可以应用不同的层级,为unstack()函数传入表示层级的编号或名称,即可对相应的层级进行操作。
ser = dframe.stack()
print(ser.unstack(0))
print('------------')
print(ser.unstack(1))
image.png
image.png

相关文章

网友评论

    本文标题:pandas

    本文链接:https://www.haomeiwen.com/subject/gunqyltx.html