这是我参与11月更文挑战的第25天,活动详情查看:2021最后一次更文挑战
Pandas简介
Pandas是基于NumPy的一个数据处理工具,该工具是为了解决数据分析任务而创建的。Pandas纳入了大量库和一些标准的数据模型,提供了高效地操作大型数据集所需的工具。Pandas提供了大量能使我们快速便捷地处理数据的函数和方法。
Pandas的主要特点
- 使用默认和自定义索引的快速高效的DataFrame对象。
- 用于将数据从不同文件格式加载到内存数据对象的工具。
- 数据对齐和缺失数据的集成处理。
- 重新设置和旋转日期集。
- 大数据集的基于标签的分片,索引和子集。
- 数据结构中的列可以被删除或插入。
- 按数据分组进行聚合和转换。
- 高性能的数据合并和连接。
- 时间序列功能,支持日期范围生成、频率转换、移动窗口统计、移动窗口线性回归、日期位移等时间序列功能。
Pandas数据结构
Pandas包含以下三个建立在Numpy数组上的数据结构 。
数据结构 | 维数 | 描述 | 描述 |
---|---|---|---|
系列(Series ) |
1 | 一维同构数组 | 均匀数据、尺寸大小不变、数据的值可变 |
数据帧(DataFrame ) |
2 | 大小可变的二维异构表格 | 异构数据、大小可变、数据可变 |
面板(Panel ) |
3 | 具有异构数据的三维数据结构 | 异构数据、大小可变、数据可变 |
考虑这些数据结构的最好方法是,较高维数据结构是其较低维数据结构的容器。 例如, DataFrame
是Series
的容器,Panel
是DataFrame
的容器。
创建对象
Pandas默认自动生成整数索引
用数组生成Series
1 | python复制代码s = pd.Series([1, 3, 5, np.nan, 6, 8]) |
运行结果:
1 | go复制代码0 1.0 |
用日期时间索引
与NumPy数组
生成DataFrame。
1 | python复制代码dates = pd.date_range('20130101', periods=6) |
运行结果:
1 | css复制代码DatetimeIndex(['2013-01-01', '2013-01-02', '2013-01-03', '2013-01-04', '2013-01-05', '2013-01-06'], |
用Series字典对象生成DataFrame
1 | python复制代码# |
运行结果:
1 | less复制代码 A B C D E F |
查看数据
查看DataFrame头部、尾部数据以及索引和列名
1 | python复制代码# 查看DataFrame头部和尾部数据 |
运行结果:
1 | css复制代码 A B C D |
DataFrame 转换成 NumPy 对象(DataFrame.to_numpy()
)
注意:
DataFrame 的列由多种数据类型组成时,该操作耗费系统资源较大。同时DataFrame.to_numpy()
的输出不包含行索引和列标签。
Pandas 和 NumPy 的本质区别:NumPy 数组只有一种数据类型,DataFrame 每列的数据类型各不相同。
当调用 DataFrame.to_numpy()
时,Pandas 查找支持 DataFrame 里所有数据类型的 NumPy 数据类型。还有一种数据类型是 object
,可以把 DataFrame 列里的值强制转换为 Python 对象。
1 | python复制代码# 当DataFrame里的值都是浮点数时,DataFrame.to_numpy()的操作会很快,而且不复制数据。 |
运行结果:
1 | css复制代码[[ 0.58115588 0.92713986 0.41851012 -0.82120405] |
快速查看数据的统计摘要
1 | python复制代码print(df.describe()) |
运行结果:
1 | matlab复制代码 A B C D |
转置数据、按轴排序和按值排序
1 | python复制代码# 转置数据 |
运行结果:
1 | yaml复制代码 2013-01-01 2013-01-02 2013-01-03 2013-01-04 2013-01-05 2013-01-06 |
参考文档
本文转载自: 掘金