合并查询 (Power Query)

合并时,通常联接两个查询,这些查询位于 Excel外部数据源中。 此外,"合并"功能具有直观的用户界面,可帮助你轻松联接两个相关表。 有关将订单明细查询的总销售额合并到产品表的示例,请参阅了解如何 合并多个数据源教程。

警告: “隐私级别”防止用户不经意组合可能属于专用或组织级别的多个数据源中的数据。 根据查询,用户可能意外将专用数据源中的数据发送到另一个可能恶意的数据源。 Power Query 分析每个数据源,并将其归类到已定义的隐私级别:公共、组织和私有。 有关隐私级别的信息,请参阅 设置隐私级别

合并查询基于两个现有查询创建新查询。 一个查询结果包含主表中的所有列,其中一列充当包含与辅助表关系的单个列。 相关表中包含基于一个公共列值与主表中每一行匹配的所有行。 “展开”操作将相关表中的列添加到主表中。 

有两种类型的合并操作:

  • 嵌入合并    将数据合并到现有查询中,直到达到最终结果。 结果是当前查询末尾的新步骤。

  • 中间合并    为每个合并操作创建新查询。

若要查看"查询依赖关系"对话框中关系的直观表示,请选择"查看">查询依赖项"。 在对话框底部,选择"布局 " 命令来控制图表方向。

"查询依赖项"对话框中的视图

至少需要两个可以合并且在联接操作中至少有一列或多列匹配的查询。 它们可能来自不同类型的外部数据源。 以下示例使用"产品"和"总销售额"。

  1. 若要打开查询,请找到以前从 Power Query 编辑器加载的查询,在数据中选择一个单元格,然后选择"查询>编辑"。 有关详细信息,请参阅在 Excel创建、加载或编辑查询

  2. 选择"主页>合并查询"。 默认操作是执行内联合并。 若要执行中间合并,请选择命令旁边的箭头,然后选择"合并查询"作为"新建"。 

    将显示 "合并 "对话框。

  3. 从第一个下拉列表中选择主表,然后通过选择列标题选择联接列。

  4. 从下一个下拉列表中选择相关表,然后通过选择列标题选择匹配的列。

    确保在主表和相关表或辅助表的预览版中选择要匹配的相同数量的列。 列比较基于每个表中的选择顺序。 匹配列必须相同,数据类型文本或数字。 还可以选择要合并的多个列。

    “合并”对话框

  5. 从主表和相关表中选择列后,Power Query 会显示一组顶部行中的匹配项数。 此操作会验证 合并操作 是否正确,或者是否需要进行更改才能获得所需的结果。 可以选择不同的表或列。

  6. 默认联接操作是内部联接,但 从"联接 类型"下拉列表中,可以选择以下类型的联接操作:

    内部联接    仅引入主表和相关表中的匹配行。

    左外部联接    保留主表中的所有行,并引入相关表中的任何匹配行。

    右外部联接    保留相关表中的所有行,并引入主表中的任何匹配行。

    完全外部    引入主表和相关表中的所有行。

    左反联接    仅引入主表中没有相关表中的任何匹配行的行。

    右反联接    仅引入相关表中没有主表中任何匹配行的行。

    交叉联接    通过将主表中的每一行与相关表中的每一行组合在一起,返回两个表中的行的笛卡尔值。

  7. 如果要执行模糊匹配,请选择"使用模糊匹配执行合并",然后从"模糊匹配"选项中进行选择。 有关详细信息,请参阅 创建模糊匹配

  8. 若要仅包含主表中与相关表匹配的行,请选择"仅包括匹配的行"。 否则,主表中的所有行将包含在生成的查询中。

  9. 选择“确定”。

结果

合并最终结果

执行 "合并 "操作后,可以展开"结构化"列,将相关表中的列添加到主表中。 将列展开到主表中后,您可以应用筛选和其他转换操作。 有关详细信息,请参阅 使用列表、记录或表结构化列

  1. 在"数据预览"中, 选择 " 展开 列标题旁边的"展开" 图标。

  2. "展开 "下拉框中,选择或清除列以显示想要的结果。 若要聚合列值,请选择"聚合 "。

    Power Query 合并

  3. 可能需要重命名新列。 有关详细信息,请参阅 重命名列

另请参阅

Microsoft Power Query for Excel 帮助 

了解如何合并多个数据源

合并查询概述 (docs.com)

左外部联接 (docs.com)

右外部联接 (docs.com)

完整外部联接 (docs.com)

内部联接 (docs.com)

左反联接 (docs.com)

右反联接 (docs.com)

交叉联接 (docs.com)

需要更多帮助?

扩展你的 Office 技能
了解培训
抢先获得新功能
加入 Office 预览体验计划

此信息是否有帮助?

×