V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐学习书目
Learn Python the Hard Way
Python Sites
PyPI - Python Package Index
http://diveintopython.org/toc/index.html
Pocoo
值得关注的项目
PyPy
Celery
Jinja2
Read the Docs
gevent
pyenv
virtualenv
Stackless Python
Beautiful Soup
结巴中文分词
Green Unicorn
Sentry
Shovel
Pyflakes
pytest
Python 编程
pep8 Checker
Styles
PEP 8
Google Python Style Guide
Code Style from The Hitchhiker's Guide
yellowtail
V2EX  ›  Python

求教 pandas 相关问题,有一个表 A,对其中一列 a 进行 groupby 和 agg(比如 count)处理后得到新表 B,如何把 B 表聚合结果列映射到 A 表?

  •  
  •   yellowtail · 2022-02-08 23:58:39 +08:00 · 2155 次点击
    这是一个创建于 1047 天前的主题,其中的信息可能已经有所发展或是发生改变。
    有一个表 A,对其中一列进行 groupby 和 agg(比如 sum)处理后得到新表 B,如何把 B 表聚合结果列映射到 A 表?

    比如表 A 是一个某地居民出生时间的表,索引是顺序时间( 2000-01-01 11:11 ),列值 datetime 对应的是日期加小时( 2000-01-01 11:00 )
    A.groupby['datetime'].count()得到表 B ,获得某天某小时出生人数
    请问如何快速在 A 表上新增一列,新列列值为 datetime 列值在 B 表中对应的出生人数?
    flyfei
        1
    flyfei  
       2022-02-09 02:39:00 +08:00 via Android
    使用 merge 方法设定为 left join 就可以吧
    milkpuff
        2
    milkpuff  
       2022-02-09 09:20:47 +08:00
    把 agg 换成 transform ,生成的结果与输入表有相同的行数。
    A.groupby['datetime'].transform('count')
    Nehcknarf
        3
    Nehcknarf  
       2022-02-09 09:29:54 +08:00
    A['new'] = A.groupby['datetime'].count()
    yellowtail
        4
    yellowtail  
    OP
       2022-02-09 13:01:41 +08:00
    @milkpuff 用你的方法解决问题了,感谢!
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2717 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 26ms · UTC 15:04 · PVG 23:04 · LAX 07:04 · JFK 10:04
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.