- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 VBA 开发 MS Excel 2013 工具,其中涉及 QueryTables 的使用。
访问 Excel 工作表中的现有查询表是一个不便之处。目前,我能找到的访问查询表的唯一方法是通过整数索引。我想出了以下代码来快速证明概念:
Sub RefreshDataQuery()
Dim querySheet As Worksheet
Dim interface As Worksheet
Set querySheet = Worksheets("QTable")
Set interface = Worksheets("Interface")
Dim sh As Worksheet
Dim QT As QueryTable
Dim startTime As Double
Dim endTime As Double
Set QT = querySheet.ListObjects.item(1).QueryTable
startTime = Timer
QT.Refresh
endTime = Timer - startTime
interface.Cells(1, 1).Value = "Elapsed time to run query"
interface.Cells(1, 2).Value = endTime
interface.Cells(1, 3).Value = "Seconds"
End Sub
这可行,但我不想这样做。最终产品工具将具有最多五个不同的查询表。我想通过名称引用查询表。
我该如何翻译:
Set QT = querySheet.ListObjects.item(1).QueryTable
类似于以下内容:
Set QT = querySheet.ListObjects.items.QueryTable("My Query Table")
最佳答案
在 Excel 2003 及更早版本中,外部数据连接将创建一个 QueryTable 对象,其父级是工作表。例如,您可以通过 QueryTables 集合对象访问 QueryTable 对象。与大多数集合对象一样,您可以将索引号或名称传递给(默认)Item 方法来获取它。
Sheet1.QueryTables("MyQtName")
当您在新版本中打开 2003 工作表时,它仍然有一个 QueryTable 对象,并且可以通过相同的方式访问。即使您转换文件格式,QueryTable 仍然存在。
在 2007 及更高版本中,只有三种方法可以创建将成为 Worksheet.QueryTables 成员的 QueryTable:
这些新版本中的所有其他 UI 外部数据连接将不会生成 QueryTables 成员,而是生成 ListObject。该 ListObject 将具有且仅有一个可通过 ListObject.QueryTable 属性访问的 QueryTable 对象。
这是个坏消息。 ListObject 中的父级 QueryTable 没有 Name 属性。嗯,它就在那里,但是如果您尝试访问它,您将收到运行时错误 1004。我猜 MS 决定,因为每个 ListObject 只有一个 QueryTable,所以它应该有一个名称是没有意义的。
如果您尝试将 Worksheet.QueryTables.QueryTable 转换为 ListObject,外部数据连接将消失,并且新的 ListObject 没有 QueryTable。
由于您的 QueryTables.Count 返回零,因此所有 QueryTables 都位于 ListObjects 内并且没有名称。 ListObjects 有名称。您可以使用
Sheet1.ListObjects("MyListName").QueryTable
这是一个函数,它接受一个名称和一个工作表,并返回一个具有该名称的 QueryTable,或者是具有该名称的 ListObject 的子级。
Public Function QueryTableByName(ByVal sName As String, ByRef sh As Worksheet) As QueryTable
Dim qt As QueryTable
Dim lo As ListObject
On Error Resume Next
Set qt = sh.QueryTables(sName)
On Error GoTo 0
If qt Is Nothing Then
On Error Resume Next
Set lo = sh.ListObjects(sName)
On Error GoTo 0
If Not lo Is Nothing Then
On Error Resume Next
Set qt = lo.QueryTable
On Error GoTo 0
End If
End If
Set QueryTableByName = qt
End Function
关于excel - 按名称引用 QueryTable 对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18067070/
我正在尝试做这样的事情:Name[i] = "Name"+ (i+1) 在 forloop 中,这样数组的值将是:Name[0] = Name1,Name[1] = Name2,Name[2] = N
我读了here,在GSP中我们可以这样写: ${params.action} 从GSP中,我们可以使用${params.action}作为参数调用Javascript函数(请参阅here)。 是否有其
我的问题:非常具体。我正在尝试想出解析以下文本的最简单方法: ^^domain=domain_value^^version=version_value^^account_type=account_ty
我创建了一条与此类似的路线: Router::connect("/backend/:controller/:action/*"); 现在我想将符合此模式的每个 Controller 路由重命名为类似
我在 Visual Studio 2013 项目中收到以下警告: SQL71502 - Procedure has an unresolved reference to object 最佳答案 这可以
任何人都可以指导我使用名称/值 .NET 集合或 .NET 名称/值字典以获得最佳性能吗?请问最好的方法是什么?我的应用程序是 ASP.NET、WCF/WF Web 应用程序。每个集合应该有 10 到
我在 Zend Framework 2 中有一个默认模块: namespace Application\Controller; use Zend\Mvc\Controller\AbstractActi
这是表格: 关于javascript - 在 javascript 中,这是一个有效的结构吗? : document. 名称.名称.值?,我们在Stack Overflow上找到一个类似的
HtmlHelper.ActionLink(htmlhelper,string linktext,string action) 如何找出正确的路线? 如果我有这个=> HtmlHelper.Actio
我需要一些有关如何将 Controller 定义传递给嵌套在 outer 指令中的 inner 指令的帮助。请参阅http://plnkr.co/edit/Om2vKdvEty9euGXJ5qan一个
请提出一个数据结构来表示内存中的记录列表。每条记录由以下部分组成: 用户名 积分 排名(基于积分)- 可选字段- 可以存储在记录中或可以动态计算 数据结构应该支持高效实现以下操作: Insert(re
错误 : 联合只能在具有兼容列类型的表上执行。 结构(层:字符串,skyward_number:字符串,skyward_points:字符串)<> 结构(skyward_number:字符串,层:字符
我想要一个包含可变数量函数的函数,但我希望在实际使用它们之前不要对它们求值。我可以使用 () => type 语法,但我更愿意使用 => type 语法,因为它似乎是为延迟评估而定制的。 当我尝试这样
我正在编写一个 elisp 函数,它将给定键永久绑定(bind)到当前主要模式的键盘映射中的给定命令。例如, (define-key python-mode-map [C-f1] 'pytho
卡在R中的错误上。 Error in names(x) <- value : 'names' attribute must be the same length as the ve
我有字符串,其中包含名称,有时在字符串中包含用户名,后跟日期时间戳: GN1RLWFH0546-2020-04-10-18-09-52-563945.txt JOHN-DOE-2020-04-10-1
有人知道为什么我会收到此错误吗?这显示将我的项目升级到新版本的Unity3d之后。 Error CS0103: The name `Array' does not exist in the curre
由于 Embarcadero 的 NNTP 服务器从昨天开始就停止响应,我想我可以在这里问:我使用非数据库感知网格,我需要循环遍历数据集以提取列数、它们的名称、数量行数以及每行中每个字段的值。 我知道
在构建Android应用程序的子项目中,我试图根据根build.gradle中的变量设置版本代码/名称。 子项目build.gradle: apply plugin: 'com.android.app
示例用例: 我有一个带有属性“myProperty”的对象,具有 getter 和 setter(自 EcmaScript 5 起支持“Property Getters 和 Setters”:http
我是一名优秀的程序员,十分优秀!