Python Pandas 合并/连接
Pandas具有完整功能、高性能的内存连接操作,与SQL等关系数据库非常相似。
Pandas提供了一个单一的函数 merge ,作为DataFrame对象之间所有标准数据库连接操作的入口点。
在这里,我们使用了以下参数−
- left − 一个DataFrame对象。
-
right − 另一个DataFrame对象。
-
on − 要连接的列(名称)。必须在左侧和右侧的DataFrame对象中找到。
-
left_on − 从左侧DataFrame中用作键的列。可以是列名称或与DataFrame长度相等的数组。
-
right_on − 从右侧DataFrame中用作键的列。可以是列名称或与DataFrame长度相等的数组。
-
left_index − 如果 True, 则使用左侧DataFrame的索引(行标签)作为其连接键。对于具有MultiIndex(分层)的DataFrame,级数的数量必须与右侧DataFrame的连接键数量匹配。
-
right_index − 对于右侧DataFrame,与 left_index 的用法相同。
-
how − 一个’left’、’right’、’outer’、’inner’之一。默认为inner。下面每种方法都有详细描述。
-
sort − 按字典顺序对连接键对应的结果DataFrame进行排序。默认为True,将其设置为False将在许多情况下大大提高性能。
现在让我们创建两个不同的DataFrames并对它们执行合并操作。
它的 输出 如下:
在关键字上合并两个数据框
它的 输出 如下所示-
多个键合并两个数据框
它的 输出 如下:
使用 ‘how’ 参数合并
merge 函数的 how 参数指定如何确定包含在合并表中的键。如果某个键的组合在左表和右表中都不存在,那么合并表中对应的值将为 NA。
下面是 how 参数选项及其 SQL 等效名称的摘要:
合并方法 | SQL等效 | 描述 |
---|---|---|
left | LEFT OUTER JOIN | 使用左对象的键 |
right | RIGHT OUTER JOIN | 使用右对象的键 |
outer | FULL OUTER JOIN | 使用键的联合 |
inner | INNER JOIN | 使用键的交集 |
左连接
它的 输出 如下 –
右连接
它的 输出 如下所示−
外连接
它的 输出 如下:
内连接
连接操作将在索引上执行。连接操作基于调用它的对象进行处理。所以, a.join(b) 并不等同于 b.join(a) 。
它的 输出 如下-