推广

pandas

iseeyu2年前 (2024-02-21)推广144

image.png

1.series构造函数:

image.png

2.series属性和方法:

image.png

3.DataFrame构造函数

image.png

4.DataFrame属性和方法

image.png

5.pandas描述性统计

image.png

6.pandas函数应用

image.png

7.迭代

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

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:分组合并

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'))

image.png

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

image.png

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

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]))

image.png

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))

image.png

image.png

扫描二维码推送至手机访问。

版权声明:本文由西安泽虎代运营发布,如需转载请注明出处。

转载请注明出处https://0291.com.cn/post/57562.html

相关文章

快手电商发布白皮书 推出“STAGE直播运营方法论”

专业化、系统化、精细化运营正在成为直播的新特征。10月27日,快手电商发布《快手电商商家运营白皮书2021》,推出“STAGE直播运营方法论”(以下简称“STAGE方法论”),帮助快手生态里的商家提升直播间运营水平,找到更明确的增长路径。STAGE方法论包括盘货品(Shap...

在线教育行业,私域转化训练营的流量实战打法

在线教育行业,私域转化训练营的流量实战打法

编辑导语:训练营模式是当下在线教育行业中常见的玩法,其中,基于不同目标,训练营的种类也有许多种,包括引流训练营、转化训练营、服务于课程的训练营等。本篇文章里,作者探讨了如何设计一个基于转化为目的的训练营,一起来看一下。 各家知识付费和在线教育转线上化的过程中,除了免费送课外,可...

我来分享网站推广的方式都有哪些(电子商务网站推广的方式有哪些)

我来分享网站推广的方式都有哪些(电子商务网站推广的方式有哪些)

在当下互联网信息时代,企业若想在互联网上进行营销推广,网站是必不可少的一项。越来越多的企业重视,企业想要营销网站能够发挥价值有好的效果,就必须做好网站推广。网站推广是一个长期的日积月累的过程,只有坚持下去才会有好的成果。下面给大家简单的介绍几种网站推广方式。 1、B2B平台免费推广。...

超级推荐人群出价怎么设置(超级推荐怎么调整出价)

超级推荐人群出价怎么设置(超级推荐怎么调整出价)

超级推荐出价是可以修改的,一般想要改价格很贱单,打开后IT亚就可以直接进行修改,但是为了不影响数据,不建议频繁的改价格。...

增长运营:从100到10万用户的活动玩法

编辑导语:基于上篇,大家了解了影响增长运营的三大要素以及增长运营的三级火箭模型后,对于理论部分都有所了解,本文主要以实战为为主,解析从100到10万的用户增长活动玩法,希望对大家有所启发。 上一次,为大家详细讲解了影响增长运营...

网站权重优化中存在哪些错误和风险?内页关键词的布局。

网站权重优化中存在哪些错误和风险?内页关键词的布局。

作为许多互联网接触到的一种网站类型,在搜索引擎优化过程中,一些优化方法有好的或坏的效果。虽然网页快照与网站权重没有直接关系,但它象征着网站的优化水平。网站权重优化中存在哪些错误和风险?网站权重优化的错误往往不同于风险网站内页目标关键字的布局。网站首页的优化尤为重要,但内页关键词的布局却被遗忘了。但...

现在,非常期待与您的又一次邂逅

我们努力让每一部企业宣传片和抖音短视频成为商业大片