网络编程
位置:首页>> 网络编程>> 网络编程>> 十分钟搞定pandas(入门教程)

十分钟搞定pandas(入门教程)

作者:ChaoSimple  发布时间:2023-08-09 01:00:15 

标签:十分钟,pandas

本文是对pandas官方网站上《10Minutes to pandas》的一个简单的翻译,原文在这里。这篇文章是对pandas的一个简单的介绍,详细的介绍请参考:Cookbook 。习惯上,我们会按下面格式引入所需要的包:

十分钟搞定pandas(入门教程)

一、创建对象

可以通过Data Structure Intro Setion 来查看有关该节内容的详细信息。

1、可以通过传递一个list对象来创建一个Series,pandas会默认创建整型索引:

十分钟搞定pandas(入门教程)

2、通过传递一个numpyarray,时间索引以及列标签来创建一个DataFrame:

十分钟搞定pandas(入门教程)

3、通过传递一个能够被转换成类似序列结构的字典对象来创建一个DataFrame:

十分钟搞定pandas(入门教程)

4、查看不同列的数据类型:

十分钟搞定pandas(入门教程)

5、如果你使用的是IPython,使用Tab自动补全功能会自动识别所有的属性以及自定义的列,下图中是所有能够被自动识别的属性的一个子集:

十分钟搞定pandas(入门教程)

二、查看数据

详情请参阅:Basics Section

1、 查看frame中头部和尾部的行:

十分钟搞定pandas(入门教程)

2、 显示索引、列和底层的numpy数据:

十分钟搞定pandas(入门教程)

3、 describe()函数对于数据的快速统计汇总:

十分钟搞定pandas(入门教程)

4、 对数据的转置:

十分钟搞定pandas(入门教程)

5、 按轴进行排序

十分钟搞定pandas(入门教程)

6、 按值进行排序

十分钟搞定pandas(入门教程)

三、选择

虽然标准的Python/Numpy的选择和设置表达式都能够直接派上用场,但是作为工程使用的代码,我们推荐使用经过优化的pandas数据访问方式: .at,.iat,.loc,.iloc和.ix详情请参阅Indexingand Selecing Data 和 MultiIndex/ Advanced Indexing。

l 获取

1、 选择一个单独的列,这将会返回一个Series,等同于df.A:

十分钟搞定pandas(入门教程)

2、 通过[]进行选择,这将会对行进行切片

十分钟搞定pandas(入门教程)

l 通过标签选择

1、 使用标签来获取一个交叉的区域

十分钟搞定pandas(入门教程)

2、 通过标签来在多个轴上进行选择

十分钟搞定pandas(入门教程)

3、 标签切片

十分钟搞定pandas(入门教程)

4、 对于返回的对象进行维度缩减

十分钟搞定pandas(入门教程)

5、 获取一个标量

十分钟搞定pandas(入门教程)

6、 快速访问一个标量(与上一个方法等价)

十分钟搞定pandas(入门教程)

l 通过位置选择

1、 通过传递数值进行位置选择(选择的是行)

十分钟搞定pandas(入门教程)

2、 通过数值进行切片,与numpy/python中的情况类似

十分钟搞定pandas(入门教程)

3、 通过指定一个位置的列表,与numpy/python中的情况类似

十分钟搞定pandas(入门教程)

4、 对行进行切片

十分钟搞定pandas(入门教程)

5、 对列进行切片

十分钟搞定pandas(入门教程)

6、 获取特定的值

十分钟搞定pandas(入门教程)

l 布尔索引

1、 使用一个单独列的值来选择数据:

十分钟搞定pandas(入门教程)

2、 使用where操作来选择数据:

十分钟搞定pandas(入门教程)

3、 使用isin()方法来过滤:

十分钟搞定pandas(入门教程)

l 设置

1、 设置一个新的列:

十分钟搞定pandas(入门教程)

2、 通过标签设置新的值:

十分钟搞定pandas(入门教程)

3、 通过位置设置新的值:

十分钟搞定pandas(入门教程)

4、 通过一个numpy数组设置一组新值:

十分钟搞定pandas(入门教程)

上述操作结果如下:

十分钟搞定pandas(入门教程)

5、 通过where操作来设置新的值:

十分钟搞定pandas(入门教程)

四、缺失值处理

在pandas中,使用np.nan来代替缺失值,这些值将默认不会包含在计算中,详情请参阅:Missing Data Section。

1、 reindex()方法可以对指定轴上的索引进行改变/增加/删除操作,这将返回原始数据的一个拷贝:、

十分钟搞定pandas(入门教程)

2、 去掉包含缺失值的行:

十分钟搞定pandas(入门教程)

3、 对缺失值进行填充:

十分钟搞定pandas(入门教程)

4、 对数据进行布尔填充:

十分钟搞定pandas(入门教程)

五、相关操作

详情请参与Basic Section On Binary Ops

l 统计(相关操作通常情况下不包括缺失值)

1、 执行描述性统计:

十分钟搞定pandas(入门教程)

2、 在其他轴上进行相同的操作:

十分钟搞定pandas(入门教程)

3、 对于拥有不同维度,需要对齐的对象进行操作。Pandas会自动的沿着指定的维度进行广播:

十分钟搞定pandas(入门教程)

l Apply

1、 对数据应用函数:

十分钟搞定pandas(入门教程)

l 直方图

具体请参照:Histogrammingand Discretization

十分钟搞定pandas(入门教程)

l 字符串方法

Series对象在其str属性中配备了一组字符串处理方法,可以很容易的应用到数组中的每个元素,如下段代码所示。更多详情请参考:Vectorized String Methods.

十分钟搞定pandas(入门教程)

六、合并

Pandas提供了大量的方法能够轻松的对Series,DataFrame和Panel对象进行各种符合各种逻辑关系的合并操作。具体请参阅:Mergingsection

l Concat

十分钟搞定pandas(入门教程)

l Join 类似于SQL类型的合并,具体请参阅:Databasestyle joining

十分钟搞定pandas(入门教程)

l Append 将一行连接到一个DataFrame上,具体请参阅Appending

十分钟搞定pandas(入门教程)

七、分组

对于”group by”操作,我们通常是指以下一个或多个操作步骤:

l (Splitting)按照一些规则将数据分为不同的组;

l (Applying)对于每组数据分别执行一个函数;

l (Combining)将结果组合到一个数据结构中;

详情请参阅:Groupingsection

十分钟搞定pandas(入门教程)

1、 分组并对每个分组执行sum函数:

十分钟搞定pandas(入门教程)

2、 通过多个列进行分组形成一个层次索引,然后执行函数:

十分钟搞定pandas(入门教程)

八、Reshaping

详情请参阅HierarchicalIndexingReshaping

l Stack

十分钟搞定pandas(入门教程)

十分钟搞定pandas(入门教程)

十分钟搞定pandas(入门教程)

l 数据透视表,详情请参阅:PivotTables.

十分钟搞定pandas(入门教程)

可以从这个数据中轻松的生成数据透视表:

十分钟搞定pandas(入门教程)

九、时间序列

Pandas在对频率转换进行重新采样时拥有简单、强大且高效的功能(如将按秒采样的数据转换为按5分钟为单位进行采样的数据)。这种操作在金融领域非常常见。具体参考:TimeSeries section

十分钟搞定pandas(入门教程)

1、 时区表示:

十分钟搞定pandas(入门教程)

2、 时区转换:

十分钟搞定pandas(入门教程)

3、 时间跨度转换:

十分钟搞定pandas(入门教程)

4、 时期和时间戳之间的转换使得可以使用一些方便的算术函数。

十分钟搞定pandas(入门教程)

十、Categorical

从0.15版本开始,pandas可以在DataFrame中支持Categorical类型的数据,详细介绍参看:categoricalintroductionAPIdocumentation

十分钟搞定pandas(入门教程)

1、 将原始的grade转换为Categorical数据类型:

十分钟搞定pandas(入门教程)

2、 将Categorical类型数据重命名为更有意义的名称:

十分钟搞定pandas(入门教程)

3、 对类别进行重新排序,增加缺失的类别:

十分钟搞定pandas(入门教程)

4、 排序是按照Categorical的顺序进行的而不是按照字典顺序进行:

十分钟搞定pandas(入门教程)

5、 对Categorical列进行排序时存在空的类别:

十分钟搞定pandas(入门教程)

十一、画图

具体文档参看:Plottingdocs

十分钟搞定pandas(入门教程)

对于DataFrame来说,plot是一种将所有列及其标签进行绘制的简便方法:

十分钟搞定pandas(入门教程)

十分钟搞定pandas(入门教程)

十二、导入和保存数据

l CSV,参考:Writingto a csv file

1、 写入csv文件:

十分钟搞定pandas(入门教程)

2、 从csv文件中读取:

十分钟搞定pandas(入门教程)

l HDF5,参考:HDFStores

1、 写入HDF5存储:

十分钟搞定pandas(入门教程)

2、 从HDF5存储中读取:

十分钟搞定pandas(入门教程)

l Excel,参考:MSExcel

1、 写入excel文件:

十分钟搞定pandas(入门教程)

2、 从excel文件中读取:

十分钟搞定pandas(入门教程)

来源:https://www.cnblogs.com/chaosimple/p/4153083.html

0
投稿

猜你喜欢

  • * 表的建立关系数据库的主要特点之一就是用表的方式组织数据。表是SQL语言存放数据、查找数据以及更新数据的基本数据结构。在SQL语言中,表有
  • 动态联接库(DLL)是加快应用程序关键部分的执行速度的重要方法,但有一点恐怕大部分人都不知道,那就是在ASP文件也能通过调用DLL来加快服务
  • 我们可以用动态产生变量的方法,从表格里捕捉数据,动态地创造“剥离”变量引号并且“清理”它,见下列代码,我们只需键入变量名称,选择 query
  • 验证关键词是否为sql保留字的在线工具:<html>      <head><t
  • 1、查看数据库中有哪些用户? select username from all_users;2、查看数据库中有哪些DBA用户? select
  • 前一段时间就安装了AspJpeg 2.0,一直没有时间去测试,直到昨天晚上因为服务器无法访问才在本机测试下,特分享下测试结果,只针对GIF图
  • 正则表达式(Regular Expression,在代码中常简写为regex、regexp或RE)是计算机科学的一个概念。正则表达式使用单个
  • 我们用session来实现这一设想。由于session是用户级的全局变量,将登录的信息记录到session中后,用户就可直接浏览这些特定的页
  • 1、XML 是什么?XML仅仅是一种数据存放格式,这种格式是一种文本(虽然XML规范中也提供了存放二进制数据的解决方案)。事实上有很多文本格
  • Photoshop Express,也就是传说中的web版photoshop,来了。和想象中的web photoshop相比,这个Photo
  • MySQL 客户端连接成功后,通过 show [session|global]status 命令 可以提供服务器状态信息,也可以在操作系统上
  • Rel-License 是微格式的开发标准之一,简单的说就是通过给引用标签(通常是链接)加上REL属性,来标明所引用链接/数据与文章的关系。
  • 下面这些命令可以在命令行下用isql执行,isql -E -Q "命令",isql.exe
  • 如何限制重复订阅邮件或投票?一、准备子程序和函数。1、初始化数据,在Session对象中保存两个变量:Sub InitializeFID()
  • 前言defer语句被用于预定对一个函数的调用。我们把这类被defer语句调用的函数称为延迟函数。而defer 延迟语句在其他编程语言里好像没
  • MySQL中模式就是数据库SHOW DATABASES;show databases;罗列所有数据库名称CREATE DATABASE &l
  • 其中 offset and fetch 最重要的新特性是 用来 分页,既然要分析 分页,就肯定要和之前的分页方式来比较了,特别是 Row_N
  • 一. 访问WEB数据库的多种方案目前在WINDOWS环境下有多种访问WEB数据库的技术,主要有:1.公共网关接口CGI(Commo
  • MySQL中有许多操作符和函数可以返回字符串。本节回答这个问题:返回的字符串使用什么字符集和 校对规则?对于简单的函数,即接收字符串输入然后
  • 作为一个非设计出生的研究思路偏向的设计师,带着少了设计师自恋和自怜的眼光,我记下最近一年来感受到的交互设计师的尴尬。交互设计师就是出界面的,
手机版 网络编程 asp之家 www.aspxhome.com