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
cuibty
V2EX  ›  Python

pandas 如何按条件去重?

  •  
  •   cuibty · 2017-02-20 22:14:12 +08:00 · 8942 次点击
    这是一个创建于 2840 天前的主题,其中的信息可能已经有所发展或是发生改变。
    数据如下:

    A | B
    -------------
    1 | 0.2
    -------------
    1 | 0.3
    -------------
    1 | 0.4
    -------------
    2 | 0.1
    -------------
    3 | 0.2
    -------------
    3 | 0.4


    按 A 列去重,保留 B 列中 最小的一行数据。
    4 条回复    2017-02-21 09:37:40 +08:00
    raptium
        1
    raptium  
       2017-02-20 22:19:43 +08:00 via iPhone
    groupby min
    raptium
        2
    raptium  
       2017-02-20 22:20:50 +08:00 via iPhone
    或者 sort_values 然后 drop_duplicates
    kingmo888
        3
    kingmo888  
       2017-02-21 00:11:58 +08:00
    ```
    import pandas as pd
    data = [[1,1,1,2,3,3], [0.2,0.3,0.4,0.1,0.2,0.4]]
    data = pd.DataFrame(data)
    data = [[1,1,1,2,3,3], [0.2,0.3,0.4,0.1,0.2,0.4]]
    data = pd.DataFrame(data).T
    data.columns=['A', 'B']
    data.groupby('A').max()
    ```
    staticor
        4
    staticor  
       2017-02-21 09:37:40 +08:00   ❤️ 1
    推荐 groupby('A', as_index=False)['B'].min() 比较直接.


    另外也推荐看一看 pivot_table 函数, 更是强大.
    ```
    df.pivot_table(index='A', columns=None, values='B', aggfunc=min)
    ```
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2792 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 29ms · UTC 11:54 · PVG 19:54 · LAX 03:54 · JFK 06:54
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.