Power Query 是 Excel 和 Power BI 中强大的数据获取、转换和加载工具

Power Query 链接是什么

Power Query 是 Excel 和 Power BI 中强大的数据获取、转换和加载工具。Power Query 链接指的是在 Excel 或 Power BI 里通过 Power Query 建立的与外部数据源的连接。这些数据源可以是各种类型,像文本文件(CSV、TXT)、数据库(SQL Server、Access)、网页、Excel 文件等。借助 Power Query 链接,你能从数据源获取数据,对其进行清洗、转换,最终加载到工作簿或报表中。

手工插入 Power Query 链接的步骤

在 Excel 中
  1. 获取数据:点击 "数据" 选项卡,在 "获取外部数据" 组中选择合适的数据源类型,比如 "自文本 / CSV""自数据库" 等。
  2. 选择数据源:在弹出的文件选择对话框或者数据库连接对话框里,选择要连接的数据源。
  3. 导航数据:Power Query 编辑器会显示数据源中的数据结构,你可以选择要加载的数据表或数据区域。
  4. 转换数据:在 Power Query 编辑器中对数据进行清洗、转换操作,例如筛选、排序、合并列等。
  5. 加载数据:完成数据转换后,点击 "关闭并上载" 按钮,将处理后的数据加载到 Excel 工作表中。

使用 VBA 代码插入 Power Query 链接

以下是一个示例代码,展示如何使用 VBA 在 Excel 中通过 Power Query 连接到 CSV 文件并加载数据:VBA

复制代码
Sub InsertPowerQueryLink()
    Dim wb As Workbook
    Dim ws As Worksheet
    Dim qt As WorkbookQuery
    Dim sourceFile As String
    Dim queryName As String
    
    ' 设置当前工作簿
    Set wb = ThisWorkbook
    ' 设置要插入数据的工作表
    Set ws = wb.Sheets("Sheet1") ' 可根据实际情况修改工作表名称
    
    ' 设置数据源文件路径
    sourceFile = "C:\YourFilePath\YourFile.csv" ' 替换为实际的 CSV 文件路径
    ' 设置查询名称
    queryName = "MyPowerQuery"
    
    ' 创建新的 Power Query 查询
    Set qt = wb.Queries.Add( _
        Name:=queryName, _
        Formula:="let" & Chr(13) & Chr(10) & _
        "    Source = Csv.Document(File.Contents(""" & sourceFile & """),[Delimiter="","", Columns=3, Encoding=1252, QuoteStyle=QuoteStyle.None])," & Chr(13) & Chr(10) & _
        "    #""Promoted Headers"" = Table.PromoteHeaders(Source, [PromoteAllScalars=true])" & Chr(13) & Chr(10) & _
        "in" & Chr(13) & Chr(10) & _
        "    #""Promoted Headers""" _
    )
    
    ' 将查询结果加载到工作表中
    ws.ListObjects.Add(SourceType:=0, Source:=qt, Destination:=ws.Range("A1")).Name = "MyTable"
End Sub

代码解释

  1. 设置工作簿和工作表
    • Set wb = ThisWorkbook:设置当前工作簿。
    • Set ws = wb.Sheets("Sheet1"):设置要插入数据的工作表,你可以根据实际情况修改工作表名称。
  2. 设置数据源文件路径和查询名称
    • sourceFile = "C:\YourFilePath\YourFile.csv":你要把这个路径替换成实际的 CSV 文件路径。
    • queryName = "MyPowerQuery":设置查询的名称。
  3. 创建新的 Power Query 查询
    • wb.Queries.Add:创建一个新的 Power Query 查询。
    • Formula:定义 Power Query 的 M 语言公式,这里是连接到 CSV 文件并提升标题行。
  4. 将查询结果加载到工作表中
    • ws.ListObjects.Add:把查询结果加载到指定的工作表区域(这里是 A1 单元格)。

使用方法

  1. 打开 Excel 文件,按下 Alt + F11 打开 VBA 编辑器。
  2. 在 VBA 编辑器中,插入一个新模块("插入" -> "模块")。
  3. 把上述代码复制到新模块中。
  4. sourceFile 变量的值替换成实际的 CSV 文件路径。
  5. 按下 F5 运行代码。

运行代码后,Excel 会通过 Power Query 连接到指定的 CSV 文件,并将数据加载到工作表中。

相关推荐
xie_pin_an12 小时前
Redis 核心命令速查表
数据库·redis·缓存
喵行星12 小时前
MySQL XtraBackup 使用文档(全量 + 增量备份与恢复)
数据库·mysql·adb
苦学编程的谢12 小时前
Redis_11_类型补充+命令补充+RESP
数据库·redis·缓存
一 乐13 小时前
社区养老保障|智慧养老|基于springboot+小程序社区养老保障系统设计与实现(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·小程序
hzk的学习笔记13 小时前
Redisson 和 Jedis 的区别
数据库·redis·缓存
我想吹水13 小时前
Django 测试样例
数据库·django·sqlite
郏国上13 小时前
遍历访问阿里云节点下的所有文件信息并写入excel文件
数据库·mongodb·阿里云·excel
小光学长13 小时前
基于Web的课前问题导入系统pn8lj4ii(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
java·前端·数据库
EasyCVR13 小时前
视频汇聚平台EasyCVR:构建通信基站“可视、可管、可控”的智慧安防体系
服务器·数据库·音视频
q***697713 小时前
Spring boot启动原理及相关组件
数据库·spring boot·后端