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

pands DataFrame meger 问题,哪位带佬帮忙解释下这是什么现象

  •  
  •   gogf · 31 天前 · 487 次点击

    pands 不熟悉,就是拿来用一下,发现这个奇怪现象 1711540567843.png

    代码:

        import pandas as pd
    
        # 初始化一个空的 DataFrame
        df = pd.DataFrame()
    
        # 添加列数据
        df['Name'] = ['Alice', 'Bob', 'Charlie']
        df['Age'] = [25, 30, 35]
        df_a = df.copy()
        df_b = df.copy()
        df_c = df.copy()
        df_d = df.copy()
        df_e = df.copy()
        meger_df = df.merge(df_a, on='Name', how='left', suffixes=('_x', '_a'))
        print(meger_df)
        meger_df = meger_df.merge(df_b, on='Name', how='left', suffixes=('_a', '_b'))
        print(meger_df)
        meger_df = meger_df.merge(df_c, on='Name', how='left', suffixes=('_b', '_c'))
        print(meger_df)
        meger_df = meger_df.merge(df_d, on='Name', how='left', suffixes=('_c', '_d')) 
        print(meger_df)
        meger_df = meger_df.merge(df_e, on='Name', how='left', suffixes=('_d', '_e')) 
        print(meger_df)
    
    1 条回复
    placeless
        1
    placeless  
       31 天前   ❤️ 1
    列名冲突时,suffix/prefix 才有效

    1. df < df_a => Age + Age => Age_x, Age_a
    2. df_a < df_b => Age_x, Age_a, + Age => Age_x, Age_a, Age
    3. df_b < df_c => Age_x, Age_a, Age, +Age => Age_x, Age_a, Age_b, Age_c

    以此类推
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   5355 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 24ms · UTC 07:16 · PVG 15:16 · LAX 00:16 · JFK 03:16
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.