python数据分析——pandas学习笔记

最近需要对Excel进行一些操作,Pandas无疑是一个很强大的一个工具,搞起来!!

Pandas简介

pandas是一个构建在Python编程语言之上快速、强大、灵活和易于使用的开源数据分析和操作工具。
pandas官网
pandas文档

安装

pip install pandas

使用

生成数据

(生成的数据data类似于excle 有行标签 index 有列标签 columns )

import pandas as pd
import numpy as np
s = pd.Series([1,3,6,np.nan,4,1]) #生成一维数组

0 1.0
1 3.0
2 6.0
3 NaN
4 4.0
5 1.0
dtype: float64

dates = pd.date_range('20160101', periods=6)#index
df = pd.DataFrame(np.random.randn(6,4), index=dates, columns=['A','B','C','D'])# 生成6*4的数据
print(df)

A B C D
2016-01-01 0.766013 0.709325 -0.177668 1.955910
2016-01-02 -0.458004 -1.522308 0.396516 1.358957
2016-01-03 -1.421787 0.978309 0.677042 1.498006
2016-01-04 0.028752 -1.021694 1.245495 -0.316957
2016-01-05 1.972788 -1.803018 -0.110645 -0.635439
2016-01-06 -0.265201 -0.310657 0.262895 1.532657

选择部分数据输出

print(df['A'])#    与 df.A 效果相同 按列标签输出

2013-01-01 -0.162028
2013-01-02 -0.247155
2013-01-03 -1.544164
2013-01-04 -1.194200
2013-01-05 2.173732
2013-01-06 -0.501831
Freq: D, Name: A, dtype: float64

print(df['20130102':'20130104']) # 根据index范围输出 若print(df['A':'C'])则会报错

A B C D
2013-01-02 -0.247155 -1.664754 2.044796 -1.647486
2013-01-03 -1.544164 -0.278302 -0.910734 -1.471865
2013-01-04 -1.194200 -1.295544 -0.522822 0.416136

# select by label: loc 通过 x y 的label 进行选择输出
print(df.loc['20130102'])
print(df.loc[:,['A','B']])
print(df.loc['20130102', ['A','B']])

A -0.247155
B -1.664754
C 2.044796
D -1.647486
Name: 2013-01-02 00:00:00, dtype: float64
A B
2013-01-01 -0.162028 -1.209992
2013-01-02 -0.247155 -1.664754
2013-01-03 -1.544164 -0.278302
2013-01-04 -1.194200 -1.295544
2013-01-05 2.173732 0.422870
2013-01-06 -0.501831 0.392393
A -0.247155
B -1.664754
Name: 2013-01-02 00:00:00, dtype: float64

# select by position: iloc 通过位置选择 即通过坐标选择(或范围)
print(df.iloc[3])
print(df.iloc[3, 1])
print(df.iloc[3:5,0:2])
print(df.iloc[[1,2,4],[0,2]])

A -1.194200
B -1.295544
C -0.522822
D 0.416136
Name: 2013-01-04 00:00:00, dtype: float64
-1.2955436468567092
A B
2013-01-04 -1.194200 -1.295544
2013-01-05 2.173732 0.422870
A C
2013-01-02 -0.247155 2.044796
2013-01-03 -1.544164 -0.910734
2013-01-05 2.173732 -0.665288

# mixed selection: ix  混合选择 即通过label 和坐标 进行选择

print(df.ix[:3, ['A', 'C']])

# Boolean indexing     逻辑选择 可以加入一些逻辑判断进行选择

print(df[df.A > 0])

A C
2013-01-01 -0.162028 -1.259382
2013-01-02 -0.247155 2.044796
2013-01-03 -1.544164 -0.910734
​ A B C D
2013-01-05 2.173732 0.42287 -0.665288 -0.585846

设置Value

#与上述差不多 还是确定要改变的数据位置即可
df.iloc[2,2] = 1111# 通过坐标位置改变
df.loc['2013-01-03', 'D'] = 2222 #通过标签确定位置 改变
df.A[df.A>0] = 0 #通过逻辑判断筛选改变
df['F'] = np.nan #通过标签改变
df['G']  = pd.Series([1,2,3,4,5,6], index=pd.date_range('20130101', periods=6))# 666
print(df)
               A         B            C            D   F  G
2013-01-01  0.000000 -0.132451     0.021797    -1.656566 NaN  1
2013-01-02 -0.182227 -0.656873    -0.633688     1.143701 NaN  2
2013-01-03  0.000000 -0.330042  1111.000000  2222.000000 NaN  3
2013-01-04 -0.664301  0.248035    -1.286524     0.879787 NaN  4
2013-01-05 -0.005037 -0.753467    -1.390868     0.842121 NaN  5
2013-01-06 -0.529367 -1.093037    -0.984761    -1.243129 NaN  6

去除 填充 判断Nan

dates = pd.date_range('20130101', periods=6)
df = pd.DataFrame(np.arange(24).reshape((6,4)), index=dates, columns=['A', 'B', 'C', 'D'])
# 先生成几个nan
df.iloc[0,1] = np.nan
df.iloc[1,2] = np.nan
df.iloc[2,:] = np.nan
print(df)
A     B     C     D
2013-01-01   0.0   NaN   2.0   3.0
2013-01-02   4.0   5.0   NaN   7.0
2013-01-03   NaN   NaN   NaN   NaN
2013-01-04  12.0  13.0  14.0  15.0
2013-01-05  16.0  17.0  18.0  19.0
2013-01-06  20.0  21.0  22.0  23.0
print(df.dropna(axis=0, how='any'))   # how={'any', 'all'} 删除任何有nan的行 (axis=1则为列)
A     B     C     D
2013-01-04  12.0  13.0  14.0  15.0
2013-01-05  16.0  17.0  18.0  19.0
2013-01-06  20.0  21.0  22.0  23.0
print(df.dropna(axis=0, how='all'))   # how={'any', 'all'} 删除全为nan的行 (axis=1则为列)
A     B     C     D
2013-01-01   0.0   NaN   2.0   3.0
2013-01-02   4.0   5.0   NaN   7.0
2013-01-04  12.0  13.0  14.0  15.0
2013-01-05  16.0  17.0  18.0  19.0
2013-01-06  20.0  21.0  22.0  23.0
print(df.fillna(value=0)) #用其它值 填充 nan
A     B     C     D
2013-01-01   0.0   0.0   2.0   3.0
2013-01-02   4.0   5.0   0.0   7.0
2013-01-03   0.0   0.0   0.0   0.0
2013-01-04  12.0  13.0  14.0  15.0
2013-01-05  16.0  17.0  18.0  19.0
2013-01-06  20.0  21.0  22.0  23.0
print(pd.isnull(df))  #判断是不是non
A      B      C      D
2013-01-01  False   True  False  False
2013-01-02  False  False   True  False
2013-01-03   True   True   True   True
2013-01-04  False  False  False  False
2013-01-05  False  False  False  False
2013-01-06  False  False  False  False

合并数据 concat

在这里插入图片描述在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

融合数据merge

可根据columns列合并和根据index索引合并
在这里插入图片描述在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

绘出数据plot

在这里插入图片描述

读取保存数据

在这里插入图片描述

总结

小心得:数据 的index可以不写 默认为0 1 2 3…,但是列columns一定要写(写成字典的形式)

参考:https://www.bilibili.com/video/BV1Ex411L7oT

  • 4
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 6
    评论
### 回答1: Pandas是一个Python库,用于数据处理和分析。在数据分析中,预处理是非常重要的一步,因为它可以帮助我们清洗和转换数据,使其更适合进行分析。Pandas提供了一些强大的预处理功能,包括数据清洗、数据转换、数据重塑和数据合并等。在使用Pandas进行数据分析时,预处理是必不可少的一步。 ### 回答2: 在数据分析中,数据的预处理是一个必要的过程。它的主要目的是清洗数据,准备数据,以便后续分析。在Python中,pandas是一种广泛使用的数据处理库。pandas可以通过其高效的数据结构和操作方法来清洗和处理数据。在本文中,将介绍pandas处理的一些常见技术。 一、读取数据 在pandas中,使用read_csv()函数读取CSV格式的数据文件,read_excel()函数读取Excel格式的数据文件。它们都有很多选项,可以根据具体文件的格式进行设置。 二、查看数据 在pandas中,使用以下函数来查看数据: 1. head() - 显示数据框的前几行; 2. tail() - 显示数据框的后几行; 3. columns - 显示数据框的列名; 4. shape - 显示数据框的行列数; 5. info() - 显示数据框的基本信息,包括每列的名称、非空值数量和数据类型。 三、数据清洗 在数据清洗中,有以下一些常见的技术: 1. 删除重复行:使用drop_duplicates()函数; 2. 替换空值:使用fillna()函数; 3. 删除空值:使用dropna()函数; 4. 更改数据类型:使用astype()函数。 四、数据准备 在数据准备中,有以下一些常见的技术: 1. 数据合并:使用merge()函数; 2. 数据筛选:使用loc()函数或者iloc()函数; 3. 数据分组:使用groupby()函数; 4. 数据排序:使用sort_values()函数。 五、数据分析数据分析中,有以下一些常见的技术: 1. 数据聚合:使用agg()函数; 2. 统计描述:使用describe()函数; 3. 数据可视化:使用matplotlib或者seaborn库。 综上所述,pandas处理数据分析中必不可少的一步。通过使用pandas提供的函数和方法,可以方便地清理和处理数据,使其更容易被分析。 ### 回答3: PandasPython中最强大的数据处理库之一,它提供了DataFrame和Series这两种数据结构,可以快速便捷地处理数据。在数据分析过程中,我们往往需要先对数据进行预处理,以便后续的分析。Pandas提供了一系列的方法和函数,可以帮助我们进行数据的预处理。 首先,在进行数据分析之前,我们需要了解自己所面对的数据类型和数据结构。Pandas中的DataFrame结构就是类似于表格的结构,每一行代表一个样本,每一列代表一个属性。Series则是一维的数组结构。通过pandas.read_csv(),我们可以读取CSV格式的数据,并转化为DataFrame结构。 接下来,我们要对数据进行一些基本的处理,例如数据清洗、数据去重、缺失值处理、异常值处理等。在数据清洗过程中,我们往往需要对数据进行一些特殊的处理,例如字符串的分割、合并、替换等操作,Pandas提供了一系列能够对文本进行操作的函数。在数据去重方面,我们可以使用drop_duplicates()函数,它可以去除DataFrame中的重复记录。在处理缺失值时,Pandas提供了一系列的函数,如fillna()函数、dropna()函数,可以方便地将NaN值变为其他有意义的值,或者删除缺失值的行或列。在异常值处理方面,我们可以使用isoutlier()函数来找到数据中的异常值,并进行处理。 在数据预处理完成后,我们可以对数据进行一些统计分析,例如计算小计、计算总计、分位数、极差、方差、标准差等统计指标。我们可以使用describe()函数来获得数据的统计描述,还可以使用groupby()函数来对数据分组,使用agg()函数对每组进行计算统计指标。此外,我们还可以对数据进行排序、丢弃、合并等操作。 总之,Pandas是一个非常强大的Python库,可以轻松处理数据预处理和数据处理方面的任务。Pandas作为数据分析和数据处理的基础库,使用熟练后可以在数据分析中发挥更大的作用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

薛定猫

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值