Pandas从入门到放弃

2024-08-13 11:15:39 浏览数 (3)

Pandas是Panel data(面板数据)和Data analysis(数据分析)的缩写,是基于NumPy的一种工具,故性能更加强劲。Pandas在管理结构数据方面非常方便,其基本功能可以大致概括为一下5类:

  • 数据 / 文本文件读取;
  • 索引、选取和数据过滤;
  • 算法运算和数据对齐;
  • 函数应用和映射;
  • 重置索引。

这些基本操作都建立在Pandas的基础数据结构之上。Pandas有两大基础数据结构:Series(一维数据结构)和DataFrame(二维数据结构)。

Series、DataFrame及其基本操作

Series 和 DataFrame 是 Pandas 的两个核心数据结构, Series 是一维数据结构,DataFrame 是二维数据结构。 Pandas 是基于 NumPy 构建的,这两大数据结构也为时间序列分析提供了很好的支持。

Series

Series是一个类似于一维数组和字典的结合,类似于Key-Value的结构,Series包括两个部分:index、values,这两部分的基础结构都是ndarray。Series可以实现转置、拼接、迭代等。使用Series之前需要先导入:

代码语言:javascript复制
import pandas as pd
import numpy as np

(1)创建Series

可以通过以下两种方式创建

代码语言:javascript复制
# 直接创建
a = pd.Series({'a' : 10, 'b' : 2, 'c' : 3})
a
代码语言:javascript复制
# 直接创建
b = pd.Series([10, 2, 3], index = ['a', 'b', 'c'])
b
代码语言:javascript复制
# 从现有数据创建
data = {'first':'hello', 'second':'world', 'third':'!!'}
c = pd.Series(data)
c

(2)访问Series中的元素

可以通过下标,也可以通过类似于字典通过key获取value

代码语言:javascript复制
a = pd.Series({'a' : 10, 'b' : 10, 'c' : 3})
a[1]#10
a['b']#10

(3)修改索引

代码语言:javascript复制
a = pd.Series({'a' : 10, 'b' : 2, 'c' : 3})
a.index = ['x', 'y', 'z']
a

(4)拼接不同的Series

代码语言:javascript复制
a = pd.Series({'a':1, 'b':2, 'c':3})
b = pd.Series([10, 2, 3], index = ['x', 'y', 'z'])
c = pd.concat([a, b])
c

DataFrame

DataFrame是一个类似于Excel表格的数据结构,索引包括行索引和列索引,每列可以是不同的数据类型(String、int、bool、...),DataFrame的每一列(行)都是一个Series,每一列(行)的Series.name即为当前列(或行)索引名。

(1)创建DataFrame

DataFrame是一个二维结构,较为常见的创建方法有:

  • 通过二维数组结构创建
  • 通过字典创建
  • 通过读取既有文件创建
代码语言:javascript复制
# 不指定行索引、列索引
arr = np.random.rand(3, 3)# 生成一个3x3的随机数矩阵
df = pd.DataFrame(arr)
display(df)

此外,也可以制定行索引和列索引,可以理解城市存储了点A、B、C的三位坐标的一个表。代码如下:

代码语言:javascript复制
# 指定行索引和列索引
df2 = pd.DataFrame(arr, index=list("xyz"), columns=list("ABC"))
display(df2)

(2)DataFrame的列操作

以前面的df2这一DataFrame变量为例,若希望获取点A的x、y、z坐标,则可以通过三种方法获取:

1、df[列索引];2、df.列索引;3、df.iloc[:, :]

注意:

在使用第一种方式时,获取的永远是列,索引只会被认为是列索引,而不是行索引;相反,第二种方式没有此类限制,故在使用中容易出现问题。第三类方法常用于获取多个列,其返回值也是一个DataFrame。以第三种方式为例:

代码语言:javascript复制
pos_A = df2.iloc[:, 0]  # 选取所有行第0列
pos_A
代码语言:javascript复制
pos_A = df2.iloc[:, 0:2]  # 选取所有行第0列和第1列
pos_A
代码语言:javascript复制
df2['B']  # 选取单列
代码语言:javascript复制
df2[['B','C']]  # 选取多列,注意是两个方括号。

如果想再df2的最后一列加上点D的坐标(1,1,1),可以通过df[列索引]=列数据的方式,代码如下:

代码语言:javascript复制
df2['D'] = [1, 1, 1]
df2

修改C的坐标为(0.6, 0.5, 0.4),并删除点B

代码语言:javascript复制
df2['C'] = [0.6, 0.5, 0.4]
del df2['B']
df2

(3) DataFrame的行操作

以处理过后的df2为例,若希望获取所有点在x轴上的位置,则可以通过两种方法:

代码语言:javascript复制
1、df.loc[行标签][列标签];2、df.iloc[:, :]

以第一种方法为例,代码如下:

代码语言:javascript复制
x = df2.loc['x']  # 选取x行
x
代码语言:javascript复制
x = df2.loc['x']['A']  # 选取x行A列的数据
x #0.13834995969465658

至此已经了解了df.loc[][]以及df.iloc[],我们可以进行一下对比:

1)使用.iloc访问数据的时候,可以不考虑数据的索引名,只需要知道该数据在整个数据集中的序号即可 2)使用.loc访问数据的时候,需要考虑数据的索引名,通过索引名来获取数据,效果与iloc一致

若想给变量再增加一个维度,例如t维度,可以通过append的方法,这个方法会返回一个新的DataFrame,而不会改变原有的DataFrame

代码语言:javascript复制
t = pd.Series([1, 1, 2], index=list("ACD"), name='t')
df3 = df2.append(t)
#display(df2)  # 无变化
df3

若想删除新增的’t’这一行,可以通过df.drop(行索引,axis)实现,axis默认值为None即删除行,若axis=1,则删除列

代码语言:javascript复制
df3.drop(['t'])
display(df3)

修改行数据的方法与列相同。

(4)DataFrame 数据查询

数据查询的方法可以分为以下五类:按区间查找、按条件查找、按数值查找、按列表查找、按函数查找。

这里以df.loc方法为例,df.iloc方法类似。先创建一个DataFrame:

代码语言:javascript复制
arr = np.array([[1, 3, 5], [0, 2, 1], [32, 2, -3]])
df = pd.DataFrame(arr, index=list("abc"), columns=list("xyz"))
df

在前面已经调到过如何使用df.loc和df.iloc按照标签值去查询,这里介绍按照区间范围进行查找,例如:获取x轴上a、b的坐标

代码语言:javascript复制
df.loc['a':'b', 'x']  # {'a':1, 'b':0}

按条件表达式查询,获取位于z轴正半轴的点的数据,代码如下:

代码语言:javascript复制
df.loc[(df['z'] > 0) & (df['z'] < 2), :]

还可以编写lambda函数来查找,获取在x、z轴正半轴的点的数据

代码语言:javascript复制
df.loc[lambda df : (df['z'] > 0) & (df['x'] > 0)]

(5)DataFrame数据统计

①数据排序

在处理带时间戳的数据时,如地铁刷卡数据等,有时需要将数据按照时间顺序进行排列,这样数据预处理时能更加方便,或者按照已有的索引给数据进行重新排序,DataFrame提供了这类方法。

代码语言:javascript复制
# 创建一个DataFrame
dfs = pd.DataFrame(np.random.random((3, 3)), index=[6, 2, 5], columns=[3, 9, 1])
dfs

按照索引升序排序,可以通过df.sort_index(axis=0, ascending=True)实现。默认通过行索引,按照升序排序

代码语言:javascript复制
newdfs1 = dfs.sort_index()
newdfs1

按照值的降序排序,可以通过df.sort_values(列索引, ascending = False)

代码语言:javascript复制
newdfs2 = dfs.sort_values(3, ascending = False)
newdfs2

②统计指标

通过DataFrame.describe()可以获取整个DataFrame不同类别的各类统计指标,先读取测试文件。

文件:https://gitee.com/kohler19/kohler19/blob/master/Python数据分析/DataSet/test1.CSV

代码语言:javascript复制
# 读取测试文件
file = pd.read_csv('./test1.CSV')
file

测试完文件记录了A~F 6个物品的大小、等级以及重量。

使用file.describe()对所有数字列进行统计,返回值中统计了个数、均值、标准差、最小值、25%-75%分位数、最大值

代码语言:javascript复制
file.describe()

通过file[].mean()或file[].max()等方法,单独计算某一列某一统计指标

代码语言:javascript复制
print(file['size'].max())  # 2999
print(file['weight'].mean())  # 144.8333

③ 分类汇总

GroupBy可以将数据按条件进行分类,进行分组索引。以另一个测试文件test2.csv为例。

https://gitee.com/kohler19/kohler19/blob/master/Python数据分析/DataSet/test2.CSV

代码语言:javascript复制
file2 = pd.read_csv('./test2.CSV')
file2

通过GroupBy可以计算目标类别的统计特征,例如按“level”将物品分类,并计算所有数字列的统计特征

代码语言:javascript复制
file2.groupby('level').describe()

除了对单一列进行分组,也可以对多个列进行分组。

例如对“level”、“place_of_production”两个列同时进行分组,希望看到每个工厂都生成了哪些类别的物品,每个类别的数字特征的均值和求和是多少

代码语言:javascript复制
df = file2.groupby(['place_of_production','level']).agg([np.mean, np.sum])
df

进一步,分析各个工厂生产不同类别商品的数量的均值和求和

代码语言:javascript复制
df2 = file2.groupby(['place_of_production','level'])['number'].agg([np.mean, np.sum])
df2

最后,如果要遍历GroupBy的结果,则不能直接打印其内容,而是要通过迭代获取

代码语言:javascript复制
# 首先尝试打印GroupBy结果
df3 = file2.groupby('place_of_production')
print(df3)  # <pandas.core.groupby.generic.DataFrameGroupBy object at 0x00000186E3D3C3D0>

当然我们可以把df3强制转换格式为list再输出,但结果并不是很方便进行进一步处理。因此,可以通过对GroupBy的结果进行遍历,再获取我们期望的信息

代码语言:javascript复制
for name, group in df3:
    print(name)  # 分组后的组名
    print(group)  # 组内信息
    print('-------------')  # 分割线

![]

Pandas与NumPy异同

1)Numpy是数值计算的扩展包,能够高效处理N维数组,即处理高维数组或矩阵时会方便。Pandas是python的一个数据分析包,主要是做数据处理用的,以处理二维表格为主。

2)Numpy只能存储相同类型的ndarray,Pandas能处理不同类型的数据,例如二维表格中不同列可以是不同类型的数据,一列为整数一列为字符串。

3)Numpy支持并行计算,所以TensorFlow2.0、PyTorch都能和numpy能无缝转换。Numpy底层使用C语言编写,效率远高于纯Python代码。

4)Pansdas是基于Numpy的一种工具,该工具是为了解决数据分析任务而创建的。Pandas提供了大量快速便捷地处理数据的函数和方法。

5)Pandas和Numpy可以相互转换,DataFrame转化为ndarray只需要使用df.values即可,ndarray转化为DataFrame使用pd.DataFrame(array)即可。

公众号本文地址:https://mp.weixin.qq.com/s/mSkA5KvL1390Js8_1ZBiyw

0 人点赞