pandas

pandas

image.png

1.series构造函数:

pandas

image.png

2.series属性和方法:

pandas

image.png

3.DataFrame构造函数

pandas

image.png

4.DataFrame属性和方法

pandas

image.png

5.pandas描述性统计

pandas

image.png

6.pandas函数应用

pandas

image.png

7.迭代

7.1 对象直接进行迭代
7.2 其他迭代

pandas

image.png

itertuples()方法将DataFrame中的每一行返回一个产生一个命名元组的迭代器。元组的第一个元素:是行的相应的索引值。而剩余的值是行值。

二.pandas实例

1.数据选择和赋值

1.排序

  • 按轴排序:df.sort_index(axis=1, ascending=False),表示:按照列索引值(axis=1),进行降序排列
  • 按值排序:df.sort_values(by=’B’)
    2.选择数据
    1)获取
  • 选择一列,产生一个‘Series’:df[‘A’] or df.A
  • 对行进行切片:df[0:3]
    2)按标签选择(loc)
  • 通过标签获取一行数据:df.loc[dates[0]]
  • 通过标签在多个轴上选择数据:df.loc[:, [‘A’, ‘B’]]
  • 通过标签同时在两个轴上切片:df.loc[‘20130102:20130104’, [‘A’, ‘B’]]
    3)按位置选择(iloc)
  • 通过传递整数的位置选择:df.iloc[3]
  • 通过整数切片:df.iloc[3:5, 0:2]. PS:最后一个不包括(左闭右开)
  • 通过传递整数列表按位置切片:df.iloc[[1,2,4], [0,2]]
  • 整行切片:df.iloc[1:3]
  • 整列切片:df.iloc[:, 1:3]
  • 获取某个具体值:df.iloc[1, 1]
  • 快速访标量:df.iat[1, 1]
    4)布尔索引
  • 使用单个列的值来选择数据:df[df.A > 0], 所有:df[]行索引, 行条件:df.A > 0
  • 从满足布尔条件的DataFrame中选择值:df[df > 0], 备注: < 0的值都变成了nan
  • 使用isin()过滤:df[df[‘E’].isin([‘two’, ‘four’])]
    5)赋值(at和iat)
  • 添加新列将自动根据索引对其数据:df[‘F’] = 1
  • 通过标签赋值:df.at[datas[0], ‘A’] = 0
  • 通过位置赋值:df.iat[0, 1] = 0
  • 使用Numpy数组赋值:df.loc[:, ‘D’] = np.array([5]*len(df))
  • 带where条件的赋值操作:df2[df2 > 0] = -df2

三.pandas数据处理

1.GroupBy:分组合并

pandas

image.png

1)过程和原理
GroupBy操作由三个阶段组成:

  • 分组:将数据分成多个组。分组标准:通常与索引或某一列具体元素有关
  • 用函数处理:用函数处理每一个分组,为每组数组生成一个单一的值
  • 合并:把来自每一组的结果汇集到一起,合并成一个新对象
    2)实例:用列元素,作为键进行分组
  • group=df[‘price1’].groupby(df[‘color’]), 得到的对象:GroupBy对象
    也可以写成:group=df.groupby(df[‘color’]).price1 or group = df.groupby(df[‘color’])[‘price1’]
    应该是:groupby的计算优先等级比较高
  • group.groups:查看分组情况
  • group.mean():对每个分组应用mean函数
  • group.sum():对每个分组应用sum函数
    3)等级分组:可以使用多列,多个键进行等级分组
  • group = df[‘price1’].groupby([df[‘color’], df[‘object’]]), 先按照color进行分组,然后再对每一组按照object进行分组
  • group.sum():最小分组,进行求和

2.merge():合并

把两个DF按照一定方式合并成一个DF

3.concat:拼接

1)concatenate()函数
numpy的concatenate()函数就是用于数组的拼接擦欧总
2)concat()函数
pandas库以及它的Series和DataFrame等数据结构实现了带编号的索引,Pandas的concat()函数实现了按索引拼接的功能
例子:

#默认axis=0
ser1 = pd.Series(np.random.rand(4), index=[1,2,3,4]), 
ser2 = pd.Series(np.random.rand(4), index=[5,6,7,8])
print(pd.concat([ser1, ser2]))

#按照axis=1
ser1 = pd.Series(np.random.rand(4), index=[1,2,3,4])
ser2 = pd.Series(np.random.rand(4), index=[5,6,7,8])
print(pd.concat([ser1, ser2], axis=1))

#内连接操作
ser1 = pd.Series(np.random.rand(4), index=[1,2,3,4])
ser2 = pd.Series(np.random.rand(4), index=[5,6,7,8])
df = pd.concat([ser1, ser2], axis=1)
print(df)
print('--------')
print(pd.concat([ser1, df], axis=1, join='inner'))

pandas

image.png

concat():默认按照axis=0这条轴进行拼接数据,并返回Series对象。如果指定axis=1, 返回的结果是DataFrame对象

pandas

image.png

concat():默认是外连结操作,把join选项设置为inner,可以执行内连接操作。

pandas

image.png

3)等级索引
假如我们想用于拼接的轴上创建等级索引,可以借助keys选项来完成,如下所示:

#axis=0方向,建立额外索引
import pandas as pd
import numpy as np

ser1 = pd.Series(np.random.rand(4), index=[1,2,3,4])
ser2 = pd.Series(np.random.rand(4), index=[5,6,7,8])
print(pd.concat([ser1, ser2], keys=[1,2]))

#axis=1方向,建立索引
ser1 = pd.Series(np.random.rand(4), index=[1,2,3,4])
ser2 = pd.Series(np.random.rand(4), index=[5,6,7,8])
print(pd.concat([ser1, ser2], axis=1,keys=[1,2]))

pandas

image.png

pandas

image.png

4)DataFrame对象的拼接

  • pd.concat([frame1, frame2])
  • pd.concat([frame1, frame2], axis=1)

4.删除数据:

  • drop():返回不包含已删除索引及其元素的新对象
  • del:删除数据列
  • drop_duplicateds():从DataFrame对象中删除所有重复的行,返回删除重复行后的DataFrame对象

1)删除Series对象数据

  • drop:ser.drop(‘yelow’) or ser.drop([‘blue’, ‘white’])
    2)删除DataFrame对象数据
  • 删除行:frame.drop([‘blue’, ‘yellow’])
  • 删除列:frame.drop([‘pen’, ‘pencil’], axis=1)。axis=1,表示跨列的方向,也就是横向的方向。找pen和pencil索引并删除
  • del:删除列的另一种方式 del frame[‘ball’]
  • 删除重复行:
    duplicated():函数可以用力啊检测重复的行,返回元素为bool的Series对象,每个元素对应一行。如果该行与前面行重复,则为True
    drop_duplicated():实现了删除功能,该函数返回删除重复行后的DataFrame对象

5.旋转数据

通常,按行或列调整元素并不总能满足目标,有时,需要按照行重新调整列或者按照列重新调整行的元素
1)DataFrame的转置

  • df.T
    2)按等级索引旋转
    前面讲过,DataFrame对象支持等级索引。利用这一点,可以还从i想你调整DataFrame对象中国呢数据,轴向旋转有两个基本操作:
  • 入栈(Stacking):旋转数据结构,把列旋转为行
  • 出栈(unStacking):把行旋转为列
import pandas as pd
import numpy as np
# df对象应用stack函数,会把列转变为行,从而得到一个Series对象
dframe = pd.DataFrame(np.arange(9).reshape(3,3),
                      index=['white', 'black', 'red'],
                      columns=['ball', 'pen', 'pencil'])
print(dframe)
print('------------')
print(dframe.stack())

#在这个具有登记索引结构的Series对象上执行unstack()操作,可以重建之前的DataFrame对象,从而可以以数据透视表的形式来展示Series对象中的等级索引结构
dframe = pd.DataFrame(np.arange(9).reshape(3,3),
                      index=['white', 'black', 'red'],
                      columns=['ball', 'pen', 'pencil'])
ser = dframe.stack()
print(ser.unstack())

#出栈可以应用不同的层级,为unstack()函数传入表示层级的编号或名称,即可对相应的层级进行操作。
ser = dframe.stack()
print(ser.unstack(0))
print('------------')
print(ser.unstack(1))

pandas

image.png

pandas

image.png

文章均来自互联网如有不妥请联系作者删除QQ:314111741 地址:http://www.mqs.net/post/15356.html

相关阅读

  • R语言dplyr包处理数据2021.3.6

    R语言dplyr包处理数据2021.3.6

    图1 筛选结果 2.2 去除重复行–distinct函数 dplyr::distinct(rbind(iris[1:10,],iris[1:20,]))#取出前10行和前20行合并后去除重复行 图2 去除结果...

    2025.12.09 05:35:02作者:iseeyu
  • 产品推广的方式有哪些(79种推广方式总有一种适合你)

    产品推广的方式有哪些(79种推广方式总有一种适合你)

    产品的推广是企业的一个重要环节。产品的推广,不仅是让消费者了解产品,而且还能够让企业在网络上获取更多品牌影响力。只有做好了产品推广,才能够让企业在品牌建设中取得更大的成就。那么产品推广应该怎么做?不同的产品使用不同推广法。但任何一...

    2025.12.09 02:51:31作者:iseeyuTags:推广
  • 淘宝怎么运营推广(中小卖家必学的操作思路)

    淘宝怎么运营推广(中小卖家必学的操作思路)

    淘宝在很长一段时间内,一直被认为是中国最大的电子商务平台。人们在这里购物,与在别处购物一样,会感觉到很便捷、很实惠。因此,随着电商行业的发展。如今,淘宝网站的活跃用户数已经超过了1亿人(目前该数据仅统计了部分用户)。而作为一个淘宝...

    2025.12.09 01:56:09作者:iseeyuTags:运营

添加新评论