Pandas 连接合并函数merge()详解_python

来源:脚本之家  责任编辑:小易  

一、merge函数用途

pandas中的merge()函数类似于SQL中join的用法,可以将不同数据集依照某些字段(属性)进行合并操作,得到一个新的数据集。

二、merge()函数的具体参数

用法:

DataFrame1.merge(DataFrame2, how=‘inner', on=None, left_on=None, right_on=None, left_index=False, right_index=False, sort=False, suffixes=('_x', ‘_y'))

参数说明

参数 说明
how 默认为inner,可设为inner/outer/left/right
on 根据某个字段进行连接,必须存在于两个DateFrame中(若未同时存在,则需要分别使用left_on和right_on来设置)
left_on 左连接,以DataFrame1中用作连接键的列
right_on 右连接,以DataFrame2中用作连接键的列
left_index 将DataFrame1行索引用作连接键
right_index 将DataFrame2行索引用作连接键
sort 根据连接键对合并后的数据进行排列,默认为True
suffixes 对两个数据集中出现的重复列,新数据集中加上后缀_x,_y进行区别

三、merge用法举例

创建两个数据框

#利用字典dict创建数据框
dataDf1=pd.DataFrame({'lkey':['foo','bar','baz','foo'],
      'value':[1,2,3,4]})
dataDf2=pd.DataFrame({'rkey':['foo','bar','qux','bar'],
      'value':[5,6,7,8]})
print(dataDf1)
print(dataDf2)
>>>
 lkey value
0 foo  1
1 bar  2
2 baz  3
3 foo  4

 rkey value
0 foo  5
1 bar  6
2 qux  7
3 bar  8

内连接(Inner)

#inner链接
dataLfDf=dataDf1.merge(dataDf2, left_on='lkey',right_on='rkey')
>>>
 lkey value_x rkey value_y
0 foo  1 foo  5
1 foo  4 foo  5
2 bar  2 bar  6
3 bar  2 bar  8

右链接(Right)

#Right链接
dataDf1.merge(dataDf2, left_on='lkey', right_on='rkey',how='right')
>>>
 lkey value_x rkey value_y
0 foo  1.0 foo  5
1 foo  4.0 foo  5
2 bar  2.0 bar  6
3 bar  2.0 bar  8
4 NaN  NaN qux  7

全链接(Outer)

#Outer链接
dataDf1.merge(dataDf2, left_on='lkey', right_on='rkey', how='outer')
>>>
 lkey value_x rkey value_y
0 foo  1.0 foo  5.0
1 foo  4.0 foo  5.0
2 bar  2.0 bar  6.0
3 bar  2.0 bar  8.0
4 baz  3.0 NaN  NaN
5 NaN  NaN qux  7.0

以上为个人经验,希望能给大家一个参考,也希望大家多多支持真格学网。如有错误或未考虑完全的地方,望不吝赐教。

您可能感兴趣的文章:详解PANDAS 数据合并与重塑(join/merge篇)pandas dataframe的合并实现(append, merge, concat)在Pandas中DataFrame数据合并,连接(concat,merge,join)的实例Pandas 合并多个Dataframe(merge,concat)的方法

  • 本文相关:
  • python自然语言编码转换模块codecs介绍
  • python 使用while写猜年龄小游戏过程解析
  • python3.6 schedule模块定时任务(实例讲解)
  • python文件操作,open读写文件,追加文本内容实例
  • python内置函数dir详解
  • 对python中不同模块(函数、类、变量)的调用详解
  • 浅析python打包工具distutils、setuptools
  • python中的with语句与上下文管理器学习总结
  • python event事件、进程池与线程池、协程解析
  • windows下sqlmap环境安装教程详解
  • 哪里有python pandas.merge函数的详解,或者哪个大...
  • 请教Python中pandas的问题,pd.merge方法?
  • pandas python怎么找合并数据
  • pandas merge 和 join的区别
  • pandas如何求交集pandas如何求交集有没有懂python...
  • python pandas 怎么读取excel的合并单元格数据
  • python 如何把多个文件内容合并到以一个文件
  • python 的pandas.merge处理后,数据在哪
  • 新手关于python中pandas函数的使用
  • python的pandas问题
  • 网站首页网页制作脚本下载服务器操作系统网站运营平面设计媒体动画电脑基础硬件教程网络安全vbsdos/bathtahtcpythonperl游戏相关vba远程脚本coldfusionruby专题autoitseraphzonepowershelllinux shellluagolangerlang其它首页详解pandas 数据合并与重塑(join/merge篇)pandas dataframe的合并实现(append, merge, concat)在pandas中dataframe数据合并,连接(concat,merge,join)的实例pandas 合并多个dataframe(merge,concat)的方法python自然语言编码转换模块codecs介绍python 使用while写猜年龄小游戏过程解析python3.6 schedule模块定时任务(实例讲解)python文件操作,open读写文件,追加文本内容实例python内置函数dir详解对python中不同模块(函数、类、变量)的调用详解浅析python打包工具distutils、setuptoolspython中的with语句与上下文管理器学习总结python event事件、进程池与线程池、协程解析windows下sqlmap环境安装教程详解python入门教程 超详细1小时学会pycharm 2020最新永久激活码(附python 列表(list)操作方法详解python 元组(tuple)操作详解python 字典(dictionary)操作详解python strip()函数 介绍pycharm 使用心得(一)安装和首pycharm 2020年最新激活码(亲测python 中文乱码问题深入分析python中使用xlrd、xlwt操作excedjango实现文件上传下载功能python gui库图形界面开发之pyqt5布局控件浅谈django channels 路由误导pyqt5 qtableview显示绑定数据的实例详解django后端接收嵌套json数据及解析详解appium+python自动化测试之运行app程序示详解python中pyyaml模块的使用python退火算法在高次方程的应用python 变量类型详解简单介绍python封装的基本知识
    免责声明 - 关于我们 - 联系我们 - 广告联系 - 友情链接 - 帮助中心 - 频道导航
    Copyright © 2017 www.zgxue.com All Rights Reserved