快速入门Pandas(一):简述、创建对象及查看数据

简介: Pandas简介Pandas是基于NumPy的一个数据处理工具,该工具是为了解决数据分析任务而创建的。Pandas纳入了大量库和一些标准的数据模型,提供了高效地操作大型数据集所需的工具。Pandas提供了大量能使我们快速便捷地处理数据的函数和方法。

Pandas简介

Pandas是基于NumPy的一个数据处理工具,该工具是为了解决数据分析任务而创建的。Pandas纳入了大量库和一些标准的数据模型,提供了高效地操作大型数据集所需的工具。Pandas提供了大量能使我们快速便捷地处理数据的函数和方法。


Pandas的主要特点

  • 使用默认和自定义索引的快速高效的DataFrame对象。
  • 用于将数据从不同文件格式加载到内存数据对象的工具。
  • 数据对齐和缺失数据的集成处理。
  • 重新设置和旋转日期集。
  • 大数据集的基于标签的分片,索引和子集。
  • 数据结构中的列可以被删除或插入。
  • 按数据分组进行聚合和转换。
  • 高性能的数据合并和连接。
  • 时间序列功能,支持日期范围生成、频率转换、移动窗口统计、移动窗口线性回归、日期位移等时间序列功能。


Pandas数据结构

Pandas包含以下三个建立在Numpy数组上的数据结构 。

数据结构 维数 描述 描述
系列(Series) 1 一维同构数组 均匀数据、尺寸大小不变、数据的值可变
数据帧(DataFrame) 2 大小可变的二维异构表格 异构数据、大小可变、数据可变
面板(Panel) 3 具有异构数据的三维数据结构 异构数据、大小可变、数据可变


考虑这些数据结构的最好方法是,较高维数据结构是其较低维数据结构的容器。 例如,  DataFrameSeries的容器,PanelDataFrame的容器。

创建对象

Pandas默认自动生成整数索引

用数组生成Series

s = pd.Series([1, 3, 5, np.nan, 6, 8])
s
复制代码


运行结果:

0    1.0
1    3.0
2    5.0
3    NaN
4    6.0
5    8.0
dtype: float64
复制代码


日期时间索引NumPy数组生成DataFrame。

dates = pd.date_range('20130101', periods=6)
print(dates)
print("--------------------------------------------")
df = pd.DataFrame(np.random.randn(6, 4), index=dates, columns=list('ABCD'))
print(df)
复制代码


运行结果:

DatetimeIndex(['2013-01-01', '2013-01-02', '2013-01-03', '2013-01-04',               '2013-01-05', '2013-01-06'],
              dtype='datetime64[ns]', freq='D')
--------------------------------------------
                   A         B         C         D
2013-01-01  0.581156  0.927140  0.418510 -0.821204
2013-01-02  0.371722 -0.064795  0.896788 -0.411426
2013-01-03  1.269228 -0.052472  0.502939  1.218583
2013-01-04 -0.305827  1.448368  1.197606 -0.329779
2013-01-05 -1.605675  2.470950  0.475849 -0.261321
2013-01-06  0.869420  0.932919  0.203338 -1.039685
复制代码


用Series字典对象生成DataFrame

# 
df2 = pd.DataFrame({'A': 1.,
      'B': pd.Timestamp('20130102'),
      'C': pd.Series(1, index=list(range(4)), dtype='float32'),
      'D': np.array([3] * 4, dtype='int32'),
      'E': pd.Categorical(["test", "train", "test", "train"]),
      'F': 'foo'})
print(df2)   
print("--------------------------------------------")
# DataFrame 的列有不同数据类型 
print(df2.dtypes)
复制代码


运行结果:

A          B    C  D      E    F
0  1.0 2013-01-02  1.0  3   test  foo
1  1.0 2013-01-02  1.0  3  train  foo
2  1.0 2013-01-02  1.0  3   test  foo
3  1.0 2013-01-02  1.0  3  train  foo
--------------------------------------------
A           float64
B    datetime64[ns]
C           float32
D             int32
E          category
F            object
dtype: object
复制代码


查看数据

查看DataFrame头部、尾部数据以及索引和列名

# 查看DataFrame头部和尾部数据
print(df.head(2))
print("---------")
print(df.tail(3))
print("---------")
# 查看索引与列名
print(df.index)
print("---------")
print(df.columns)
复制代码


运行结果:

A         B         C         D
2013-01-01  0.581156  0.927140  0.418510 -0.821204
2013-01-02  0.371722 -0.064795  0.896788 -0.411426
---------
                   A         B         C         D
2013-01-04 -0.305827  1.448368  1.197606 -0.329779
2013-01-05 -1.605675  2.470950  0.475849 -0.261321
2013-01-06  0.869420  0.932919  0.203338 -1.039685
---------
DatetimeIndex(['2013-01-01', '2013-01-02', '2013-01-03', '2013-01-04',               '2013-01-05', '2013-01-06'],
              dtype='datetime64[ns]', freq='D')
---------
Index(['A', 'B', 'C', 'D'], dtype='object')
复制代码


DataFrame 转换成 NumPy 对象(DataFrame.to_numpy())

注意: DataFrame 的列由多种数据类型组成时,该操作耗费系统资源较大。同时DataFrame.to_numpy() 的输出不包含行索引和列标签。

Pandas 和 NumPy 的本质区别:NumPy 数组只有一种数据类型,DataFrame 每列的数据类型各不相同。

当调用 DataFrame.to_numpy() 时,Pandas 查找支持 DataFrame 里所有数据类型的 NumPy 数据类型。还有一种数据类型是 object,可以把 DataFrame 列里的值强制转换为 Python 对象。

# 当DataFrame里的值都是浮点数时,DataFrame.to_numpy()的操作会很快,而且不复制数据。
print(df.to_numpy())
print("------------")
# 当DataFrame中包含了多种类型,DataFrame.to_numpy()的操作就会耗费较多资源。
print(df2.to_numpy())
复制代码


运行结果:

[[ 0.58115588  0.92713986  0.41851012 -0.82120405]
 [ 0.37172229 -0.06479531  0.89678779 -0.41142571]
 [ 1.26922774 -0.05247208  0.50293895  1.21858323]
 [-0.30582652  1.4483678   1.19760636 -0.3297786 ]
 [-1.60567514  2.47095001  0.47584868 -0.26132112]
 [ 0.86941951  0.93291938  0.20333811 -1.03968497]]
------------
[[1.0 Timestamp('2013-01-02 00:00:00') 1.0 3 'test' 'foo']
 [1.0 Timestamp('2013-01-02 00:00:00') 1.0 3 'train' 'foo']
 [1.0 Timestamp('2013-01-02 00:00:00') 1.0 3 'test' 'foo']
 [1.0 Timestamp('2013-01-02 00:00:00') 1.0 3 'train' 'foo']]
复制代码


快速查看数据的统计摘要

print(df.describe())
复制代码


运行结果:

A         B         C         D
count  6.000000  6.000000  6.000000  6.000000
mean   0.196671  0.943685  0.615838 -0.274139
std    1.027852  0.958853  0.362994  0.791918
min   -1.605675 -0.064795  0.203338 -1.039685
25%   -0.136439  0.192431  0.432845 -0.718759
50%    0.476439  0.930030  0.489394 -0.370602
75%    0.797354  1.319506  0.798326 -0.278435
max    1.269228  2.470950  1.197606  1.218583
复制代码


转置数据、按轴排序和按值排序

# 转置数据
print(df.T)
print("----------------------")
# 按轴排序:ascending=False表示降序,默认为升序, axis=1表示列
print(df.sort_index(axis=1, ascending=False))
# axis=0表示行
print(df.sort_index(axis=0, ascending=False))
print("----------------------")
# 按值排序
print(df.sort_values(by='B'))
复制代码


运行结果:

2013-01-01  2013-01-02  2013-01-03  2013-01-04  2013-01-05  2013-01-06
A    0.581156    0.371722    1.269228   -0.305827   -1.605675    0.869420
B    0.927140   -0.064795   -0.052472    1.448368    2.470950    0.932919
C    0.418510    0.896788    0.502939    1.197606    0.475849    0.203338
D   -0.821204   -0.411426    1.218583   -0.329779   -0.261321   -1.039685
----------------------
                   D         C         B         A
2013-01-01 -0.821204  0.418510  0.927140  0.581156
2013-01-02 -0.411426  0.896788 -0.064795  0.371722
2013-01-03  1.218583  0.502939 -0.052472  1.269228
2013-01-04 -0.329779  1.197606  1.448368 -0.305827
2013-01-05 -0.261321  0.475849  2.470950 -1.605675
2013-01-06 -1.039685  0.203338  0.932919  0.869420
                   A         B         C         D
2013-01-06  0.869420  0.932919  0.203338 -1.039685
2013-01-05 -1.605675  2.470950  0.475849 -0.261321
2013-01-04 -0.305827  1.448368  1.197606 -0.329779
2013-01-03  1.269228 -0.052472  0.502939  1.218583
2013-01-02  0.371722 -0.064795  0.896788 -0.411426
2013-01-01  0.581156  0.927140  0.418510 -0.821204
----------------------
                   A         B         C         D
2013-01-02  0.371722 -0.064795  0.896788 -0.411426
2013-01-03  1.269228 -0.052472  0.502939  1.218583
2013-01-01  0.581156  0.927140  0.418510 -0.821204
2013-01-06  0.869420  0.932919  0.203338 -1.039685
2013-01-04 -0.305827  1.448368  1.197606 -0.329779
2013-01-05 -1.605675  2.470950  0.475849 -0.261321



相关文章
|
4天前
|
数据采集 数据可视化 数据处理
Pandas高级数据处理:数据仪表板制作
《Pandas高级数据处理:数据仪表板制作》涵盖数据清洗、聚合、时间序列处理等技巧,解决常见错误如KeyError和内存溢出。通过多源数据整合、动态数据透视及可视化准备,结合性能优化与最佳实践,助你构建响应快速、数据精准的商业级数据仪表板。适合希望提升数据分析能力的开发者。
57 31
|
5天前
|
数据采集 并行计算 数据可视化
Pandas高级数据处理:数据报告生成实战指南
数据报告生成面临数据质量、计算性能、呈现形式和自动化等核心挑战。常见问题包括缺失值导致统计失真、内存溢出及可视化困难。解决方案涵盖数据清洗、分块处理、安全绘图模板等。通过模块化设计、异常处理机制和性能优化策略,如使用`category`类型、并行计算等,可大幅提升效率。最佳实践建议建立数据质量检查清单、版本控制和自动化测试框架,确保系统具备自适应能力,提升报告生成效率300%以上。
38 12
|
11天前
|
监控 物联网 数据处理
Pandas高级数据处理:数据流式计算
本文介绍了如何使用 Pandas 进行流式数据处理。流式计算能够实时处理不断流入的数据,适用于金融交易、物联网监控等场景。Pandas 虽然主要用于批处理,但通过分块读取文件、增量更新 DataFrame 和使用生成器等方式,也能实现简单的流式计算。文章还详细讨论了内存溢出、数据类型不一致、数据丢失或重复及性能瓶颈等常见问题的解决方案,并建议在处理大规模数据时使用专门的流式计算框架。
138 100
Pandas高级数据处理:数据流式计算
|
28天前
|
机器学习/深度学习 搜索推荐 数据挖掘
Pandas数据应用:广告效果评估
在数字化营销中,广告效果评估至关重要。Pandas作为Python的强大数据分析库,在处理广告数据时表现出色。本文介绍如何使用Pandas进行广告效果评估,涵盖数据读取、预览、缺失值处理、数据类型转换及常见报错解决方法,并通过代码案例详细解释。掌握这些技能,可为深入分析广告效果打下坚实基础。
41 17
|
29天前
|
数据采集 供应链 数据可视化
Pandas数据应用:供应链优化
在当今全球化的商业环境中,供应链管理日益复杂。Pandas作为Python的强大数据分析库,能有效处理库存、物流和生产计划中的大量数据。本文介绍如何用Pandas优化供应链,涵盖数据导入、清洗、类型转换、分析与可视化,并探讨常见问题及解决方案,帮助读者在供应链项目中更加得心应手。
50 21
|
30天前
|
数据采集 存储 供应链
Pandas数据应用:库存管理
本文介绍Pandas在库存管理中的应用,涵盖数据读取、清洗、查询及常见报错的解决方法。通过具体代码示例,讲解如何处理多样数据来源、格式不一致、缺失值和重复数据等问题,并解决KeyError、ValueError等常见错误,帮助提高库存管理效率和准确性。
106 72
|
1月前
|
机器学习/深度学习 数据采集 供应链
Pandas数据应用:销售预测
本文介绍如何使用Pandas进行销售预测。首先,通过获取、清洗和可视化历史销售数据,确保数据质量并理解其特征。接着,进行特征工程,构建线性回归等模型进行预测,并评估模型性能。最后,针对常见问题如数据类型不匹配、时间格式错误、内存不足和模型过拟合提供解决方案。掌握这些步骤,可有效提升销售预测的准确性,助力企业优化库存管理和提高客户满意度。
55 17
|
1月前
|
机器学习/深度学习 存储 算法
Pandas数据应用:客户流失预测
本文介绍如何使用Pandas进行客户流失预测,涵盖数据加载、预处理、特征工程和模型训练。通过解决常见问题(如文件路径错误、编码问题、列名不一致等),确保数据分析顺利进行。特征工程中创建新特征并转换数据类型,为模型训练做准备。最后,划分训练集与测试集,选择合适的机器学习算法构建模型,并讨论数据不平衡等问题的解决方案。掌握这些技巧有助于有效应对实际工作中的复杂情况。
142 95
|
1月前
|
数据采集 存储 算法
Pandas数据应用:市场篮子分析
市场篮子分析是一种用于发现商品间关联关系的数据挖掘技术,广泛应用于零售业。Pandas作为强大的数据分析库,在此领域具有显著优势。本文介绍了市场篮子分析的基础概念,如事务、项集、支持度、置信度和提升度,并探讨了数据预处理、算法选择、参数设置及结果解释中的常见问题与解决方案,帮助用户更好地进行市场篮子分析,为企业决策提供支持。
70 29
|
1月前
|
机器学习/深度学习 BI 定位技术
Pandas数据应用:用户细分
用户细分是数据分析和商业智能中的关键步骤,通过将用户群体划分为不同子集,企业可以更精准地了解用户需求并制定营销策略。Pandas 是 Python 中常用的数据处理库,支持高效的数据操作。使用 Pandas 进行用户细分包括数据准备、清洗、特征工程、细分和结果分析等步骤。常见问题如数据类型不一致、内存不足等可通过相应方法解决。Pandas 简化了用户细分流程,帮助获取有价值的洞察。
59 24