• 多张excel表做连接,就比如1表有A,B,C列,2表有A,B,D列,我想把A,B,C,D合到一张表


    大家好,我是皮皮。

    一、前言

    前几天在Python铂金群有个叫【水方人子】的粉丝问了一个关于excel处理的问题,这里拿出来给大家分享下,一起学习。

    image.png

    能不能把多张excel表做连接,就比如1表有A,B,C列,2表有A,B,D列,我想把A,B,C,D合到一张表上面,可以吗,就跟数据库左连接一样?

    二、解决过程

    一开始想到的方法是Excel中的vlookup函数,确实是可以做。

    image.png

    不过在Python群里边,还是尽量用Python来操作一发,这里【Lee】大佬给了几个代码。

    image.png

    代码这里贴出来了,如下所示:

    import pandas as pd 
    
    #用append
    df = pd.read_excel(r"C:\Users\Administrator\Downloads\test.xlsx", sheet_name=['Sales','Return','Purchase'])
    sales = df.get('Sales')
    ret = df.get('Return')
    purchase = df .get('Purchase')
    result = sales.append([ret,purchase], sort=False)
    result
    
    

    image.png

    之后用merge来操作,代码如下。

    左连接的代码如下:

    xc = pd.merge(sales,ret, how='left')
    xc
    
    

    image.png

    右链接的代码如下:

    pd.merge(xc,purchase, how='right')
    
    

    image.png

    之后用concat连接,代码如下:

    # 用concat连接
    df_contact = pd.concat(pd.read_excel(r"C:\Users\Administrator\Downloads\test.xlsx", sheet_name=None), ignore_index=True)
    df_contact
    
    

    image.png

    三、总结

    大家好,我是皮皮。这篇文章基于粉丝提问,针对多张excel表做连接,就比如1表有A,B,C列,2表有A,B,D列,我想把A,B,C,D合到一张表的问题,给出了具体说明和演示,顺利地帮助粉丝解决了问题!

    最后感谢粉丝【水方人子】提问,感谢【Lee】大佬给出的示例和代码支持,感谢粉丝【月神】、【铭记yu心】、【杨羊】、【dcpeng】、【LEE】、【冫马讠成】等人参与学习交流。

  • 相关阅读:
    单行道
    学习C++50条忠告
    ROI
    OpenCV(图像处理)—访问像素的三种方法
    毕业课题项目——基于单目摄像头的距离测量
    API
    MFC
    STL
    debug、release
    Android中退出程序的提示框
  • 原文地址:https://www.cnblogs.com/dcpeng/p/16123108.html
Copyright © 2020-2023  润新知