博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
DataFrame.apply vs. group.apply vs.Series.apply
阅读量:6500 次
发布时间:2019-06-24

本文共 1066 字,大约阅读时间需要 3 分钟。

df

Out[87]:
   A  B  C
0  a  1  4
1  a  2  6
2  b  3  5

 

g = df.groupby('A')

 

g.apply(f) #f:形参为DataFrame

g['B'].apply(f) #f:形参为Series

 

df[['B','C']].apply(f)#f:形参为列或行(axis=1)

series.apply(f) #f:形参为元素;相当于Series.map(f)

 

#以上函数均可继续传入位置参数:f(s,k1=...,k2=...,k3=....); apply(f,k1=?,k2=?,k3=?)

 

df.groupby('A').apply(lambda x:DataFrame({"min":x.min(),"idxmin":x.idxmin()}))

Out[95]:
     min  idxmin
A              
a B    1       0
  C    4       0
b B    3       2
  C    5       2

g=df.groupby('A')

def f(frame):

    return frame.apply(lambda s:Series([s.min(),s.max()],index=['min','max']))

 

g.apply(f)

Out[98]:
       A  B  C
A            
a min  a  1  4
  max  a  2  6
b min  b  3  5
  max  b  3  5

 

def f2(frame):

    return frame.apply(lambda s:Series([s.min(),s.argmin()],index=['min','argmin']))

 

g.apply(f2)

E:\Anaconda3\lib\site-packages\ipykernel_launcher.py:2: FutureWarning: 'argmin' is deprecated, use 'idxmin' instead. The behavior of 'argmin'
will be corrected to return the positional minimum in the future.
Use 'series.values.argmin' to get the position of the minimum now.
 
Out[104]:
          B  C
A            
a min     1  4
  argmin  0  0
b min     3  5
  argmin  2  2

转载于:https://www.cnblogs.com/ziheIT/p/9256213.html

你可能感兴趣的文章
我的友情链接
查看>>
CoreOS 手动更新
查看>>
golang 分页
查看>>
再论机械式针对接口编程
查看>>
25 个 Linux 性能监控工具
查看>>
C#程序员整理的Unity 3D笔记(十三):Unity 3D基于组件的思想
查看>>
Tengine-2.1.1 ngx_http_concat_module 400问题
查看>>
Windows中挂载安装ISO文件
查看>>
Wayland 1.0发布
查看>>
golang的goroutine是如何实现的?
查看>>
乐视云基于Kubernetes的PaaS平台建设
查看>>
R 学习笔记《十》 R语言初学者指南--图形工具
查看>>
PHP通过读取DOM抓取信息
查看>>
DICOM医学图像处理:DICOM网络传输
查看>>
nio和传统Io的区别
查看>>
移动端网页布局中需要注意事项以及解决方法总结
查看>>
(原创)Linux下查看系统版本号信息的方法
查看>>
oracle
查看>>
redis使用过程中主机内核层面的一些优化
查看>>
我也要谈谈大型网站架构之系列(2)——纵观历史演变(下)
查看>>