热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

如何在VBA中自动执行电源查询?

如何解决《如何在VBA中自动执行电源查询?》经验,为你挑选了2个好方法。

我在表1中有数据.通常我会进行电源查询并进行转换,然后关闭,并加载到现有工作表2.

我想使用VBA自动执行此操作,我可以自动运行电源查询并将转换填充到第2页.

宏录制器似乎不允许我记录步骤.在网上没有太多关于这样做的事情.

尝试一些更简单的代码:

Sub LoadToWorksheetOnly()

'Sub LoadToWorksheetOnly(query As WorkbookQuery, currentSheet As Worksheet)
    ' The usual VBA code to create ListObject with a Query Table
    ' The interface is not new, but looks how simple is the conneciton string of Power Query:
    ' "OLEDB;Provider=Microsoft.Mashup.OleDb.1;Data Source=$Workbook$;Location=" & query.Name

    query = Sheets("Sheet6").Range("A1").value 'here is where my query from power query is. I put the text from power query avanced editor in another sheet cell.
    currentSheet = ActiveSheet.Name
    With ActiveSheet.ListObjects.Add(SourceType:=0, Source:= _
        "OLEDB;Provider=Microsoft.Mashup.OleDb.1;Data Source=$Workbook$;Location=" & query.Name _
        , Destination:=Sheets("target").Range("$A$1")).QueryTable
        .CommandType = xlCmdDefault
        .CommandText = Array("SELECT * FROM [" & query.Name & "]")
        .RowNumbers = False
        .FillAdjacentFormulas = False
        .PreserveFormatting = True
        .RefreshOnFileOpen= False
        .BackgroundQuery = True
        .RefreshStyle = xlInsertDeleteCells
        .SavePassword = False
        .SaveData = True
        .AdjustColumnWidth = True
        .RefreshPeriod = 0
        .PreserveColumnInfo = False
        .Refresh BackgroundQuery:=False
    End With

End Sub

尝试手动加载到新工作表时,这是我的问题.

在此输入图像描述



1> QHarr..:

WIP:

那么如何写这个就足够了?最重要的是,您应该使用内置工具设置您的查询.不是VBA.您可以通过适当的方法加载数据,该方法可以来自文件,循环文件夹,Web,数据库....列表继续.您可以从外部源导入以及从内部加载.有关从外部源加载的更多信息,请查看此处.

一旦您保护了源并加载了源,您将看到查询编辑器,您可以在其中执行转换步骤.

关键是当您使用UI执行步骤时,M代码将在后台编写,并形成可重复使用查询的基础,前提是您不要更改源格式或位置.

在您的情况下,当您执行了步骤并根据需要进行查询时,请关闭并加载到sheet2.

在此步骤中,第一次进行此设置时,您将选择工作表2作为关闭和加载目标:

关闭并加载

注意:当您选择现有工作表时,请确保工作表2已存在,您可以手动编辑Sheet2!在建议的范围之前.


您遇到了问题,因为您一直在尝试使用代码重新创建所有这些问题.别.使用UI进行设置并加载到sheet2.从那时起,打开查询编辑器以编辑步骤和/或刷新查询以使用新/刷新的数据加载现有的sheet2.


一些用于刷新查询的可用方法:

该查询将通过VBA /手动刷新刷新以它驻留在(Sheet 2中),或以工作簿本身的片材例如Sheet2.Calculate,ThisWorkbook.RefreshAll在数据标签手动按压刷新工作簿按钮(这些都是矫枉过正真的)

刷新所有选项卡

有针对性的方法:

表2中查询表的VBA:

ThisWorkbook.Worksheets("Sheet2").ListObjects(1).QueryTable.Refresh BackgroundQuery:=False   

将上述内容更改为相应的表格等.

右键单击查询表本身并选择刷新:

刷新

单击右侧工作簿查询窗口中的刷新按钮以查询相关查询(带有绿色圆圈箭头的图标)

刷新


在肯拉手 VBA方式(小编辑从我这里)

Option Explicit
Public Sub UpdatePowerQueries()
    ' Macro to update my Power Query script(s)

    Dim lTest As Long, cn As WorkbookConnection
    On Error Resume Next
    For Each cn In ThisWorkbook.Connections
        lTest = InStr(1, cn.OLEDBConnection.Connection, "Provider=Microsoft.Mashup.OleDb.1", vbTextCompare)
        If Err.Number <> 0 Then
            Err.Clear
            Exit For
        End If
        If lTest > 0 Then cn.Refresh
    Next cn
    On Error GoTo 0
End Sub

您不应该真正需要通过VBA完成所有这些工作.您可能有一些棘手的数据操作,您觉得使用VBA更舒服,然后使用powerquery访问处理数据作为源.你可以通过调用处理例程然后使用上面列出的vba命令方法之一来触发整个批次.还有更多方法,我会在有更多时间时添加它们.


计算:

如果您的计算依赖于powerquery输出,那么您有4个明显的即时选项:

    尽可能将这些计算添加到powerquery中.它支持计算列,用户定义函数等等.

    将powerquery输出添加到数据模型,并使用数据模型执行包括计算字段的计算.这将使您可以访问时间智能功能.

    如果范围在刷新时更改,则使用VBA将计算添加到工作表2中的相应区域

    如果范围在刷新时没有改变,只需将您的公式放在一边.



2> mer_curius..:

我不同意以上回答的前提;VBA绝对适合于PowerQuery的自动化,并且对于重复工作特别有效。诀窍是先在PowerQuery中创建所需的查询,然后使用“高级编辑器”捕获M。将其复制并存储在工作簿的单元格中或单独的文本文件中。

该方法由Gil Raviv详细介绍。为了方便起见,我将M存储在文本文件中而不是工作簿中,并使用以下命令加载它:

Function LoadTextFile(FullFileName As String) As String
  With CreateObject("Scripting.FileSystemObject")
    LoadTextFile = .OpenTextFile(FullFileName, 1).readall
  End With 
End Function

关于文本文件的好处是它们独立于excel,并且可以被许多工作簿重复使用。

这是一些M:

Function LoadTextFile(FullFileName As String) As String
  With CreateObject("Scripting.FileSystemObject")
    LoadTextFile = .OpenTextFile(FullFileName, 1).readall
  End With 
End Function

推荐阅读
  • 本文介绍了Windows Vista操作系统中的用户账户保护功能,该功能是为了增强系统的安全性而设计的。通过对Vista测试版的体验,可以看到系统在安全性方面的进步。该功能的引入,为用户的账户安全提供了更好的保障。 ... [详细]
  • Codebelowwascreated(notbyme,andsavedas*.dotm)inMicrosoftWord97-2003,whendefaultins ... [详细]
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • 知识图谱——机器大脑中的知识库
    本文介绍了知识图谱在机器大脑中的应用,以及搜索引擎在知识图谱方面的发展。以谷歌知识图谱为例,说明了知识图谱的智能化特点。通过搜索引擎用户可以获取更加智能化的答案,如搜索关键词"Marie Curie",会得到居里夫人的详细信息以及与之相关的历史人物。知识图谱的出现引起了搜索引擎行业的变革,不仅美国的微软必应,中国的百度、搜狗等搜索引擎公司也纷纷推出了自己的知识图谱。 ... [详细]
  • sklearn数据集库中的常用数据集类型介绍
    本文介绍了sklearn数据集库中常用的数据集类型,包括玩具数据集和样本生成器。其中详细介绍了波士顿房价数据集,包含了波士顿506处房屋的13种不同特征以及房屋价格,适用于回归任务。 ... [详细]
  • ShiftLeft:将静态防护与运行时防护结合的持续性安全防护解决方案
    ShiftLeft公司是一家致力于将应用的静态防护和运行时防护与应用开发自动化工作流相结合以提升软件开发生命周期中的安全性的公司。传统的安全防护方式存在误报率高、人工成本高、耗时长等问题,而ShiftLeft提供的持续性安全防护解决方案能够解决这些问题。通过将下一代静态代码分析与应用开发自动化工作流中涉及的安全工具相结合,ShiftLeft帮助企业实现DevSecOps的安全部分,提供高效、准确的安全能力。 ... [详细]
  • Jboss的EJB部署描述符standardjaws.xml配置步骤详解
    本文详细介绍了Jboss的EJB部署描述符standardjaws.xml的配置步骤,包括映射CMP实体EJB、数据源连接池的获取以及数据库配置等内容。 ... [详细]
  • 因此,我设法获取了此宏以创建新的工作表,从单元格值命名工作表,并将一些 ... [详细]
  • 生成式对抗网络模型综述摘要生成式对抗网络模型(GAN)是基于深度学习的一种强大的生成模型,可以应用于计算机视觉、自然语言处理、半监督学习等重要领域。生成式对抗网络 ... [详细]
  • Spring源码解密之默认标签的解析方式分析
    本文分析了Spring源码解密中默认标签的解析方式。通过对命名空间的判断,区分默认命名空间和自定义命名空间,并采用不同的解析方式。其中,bean标签的解析最为复杂和重要。 ... [详细]
  • VScode格式化文档换行或不换行的设置方法
    本文介绍了在VScode中设置格式化文档换行或不换行的方法,包括使用插件和修改settings.json文件的内容。详细步骤为:找到settings.json文件,将其中的代码替换为指定的代码。 ... [详细]
  • 本文介绍了数据库的存储结构及其重要性,强调了关系数据库范例中将逻辑存储与物理存储分开的必要性。通过逻辑结构和物理结构的分离,可以实现对物理存储的重新组织和数据库的迁移,而应用程序不会察觉到任何更改。文章还展示了Oracle数据库的逻辑结构和物理结构,并介绍了表空间的概念和作用。 ... [详细]
  • 本文介绍了Hyperledger Fabric外部链码构建与运行的相关知识,包括在Hyperledger Fabric 2.0版本之前链码构建和运行的困难性,外部构建模式的实现原理以及外部构建和运行API的使用方法。通过本文的介绍,读者可以了解到如何利用外部构建和运行的方式来实现链码的构建和运行,并且不再受限于特定的语言和部署环境。 ... [详细]
  • 解决Cydia数据库错误:could not open file /var/lib/dpkg/status 的方法
    本文介绍了解决iOS系统中Cydia数据库错误的方法。通过使用苹果电脑上的Impactor工具和NewTerm软件,以及ifunbox工具和终端命令,可以解决该问题。具体步骤包括下载所需工具、连接手机到电脑、安装NewTerm、下载ifunbox并注册Dropbox账号、下载并解压lib.zip文件、将lib文件夹拖入Books文件夹中,并将lib文件夹拷贝到/var/目录下。以上方法适用于已经越狱且出现Cydia数据库错误的iPhone手机。 ... [详细]
  • SpringBoot整合SpringSecurity+JWT实现单点登录
    SpringBoot整合SpringSecurity+JWT实现单点登录,Go语言社区,Golang程序员人脉社 ... [详细]
author-avatar
最棒的寒冬腊月_531
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有