- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
美好的一天,
我在设置范围方面遇到问题,并且在使用非事件工作表中的设置范围时非常令人沮丧。
问题是:
我有一个名为“仪表板”的工作表。在此工作表中,我有一个列表框,选择该列表框时将过滤另一个名为“预算”的工作表中的表上的值(基于 listbox.column 值)。但是,我收到错误 1004(Range 类的自动筛选方法失败),在关闭错误后,它会筛选范围。所以看起来它以某种方式工作,但是它给了我错误。
下面的代码是我用来过滤范围的代码。它被插入到“仪表板”工作表对象中。
Private Sub DashboardBudgetlst_Change()
Dim rng As Range
Dim i As Integer
i = Me.DashboardBudgetlst.ListIndex
If i >= 0 Then
If Me.DashboardBudgetlst.Selected(i) And Me.DashboardBudgetlst.Column(0, i) <> "" Then
Set rng = Budget.Range("B1:E" & lrow(Budget, "A"))
rng.AutoFilter 1, Me.DashboardBudgetlst.Column(1, i)
Set rng = Nothing
End If
End If
End Sub
该宏将过滤用于图表的范围,因此将过滤我的图表的值。另外我不想使用数据透视表,因为它非常慢。
进一步探讨这个问题。如何使用在另一个工作表中设置的一个工作表中的范围,而无需激活该范围的工作表? (大多数时候我必须在使用该工作表的设置范围之前执行 Sheet.Activate )。
你们知道解决方法以及为什么设置范围会出现这个问题吗?
我知道也有关于范围的类似问题,但没有一个具有相同的规范。
1-在线错误:
rng.AutoFilter 1, Me.DashboardBudgetlst.Column(1, i)
2- 列表框索引 >= 0 以确保列表框不为空并且已选择一个项目。当列表框为空时,列表索引 = -1。
3- lrow(Budget, "A") 调用以下函数来获取指定工作表中的最后一行:
Function lrow(SH As Worksheet, col As String)
lrow = SH.Cells(Rows.Count, col).End(xlUp).Row
End Function
4- 在错误行之前使用 msgbox rng.address,我收到 $B$1:$E$5 作为地址。
5-我使用了一个临时解决方法
On Error Resume Next
6- Me.DashboardBudgetlst.Column(1, i) 的值是要过滤的关键字,取决于选择。列表框的输入范围与我正在过滤的范围相同。因此,我从标题“Item”下的列表中选择列“1”。当我从列表框中选择某些内容时,我希望它按该预算项目进行过滤,有时可以是“住宿”或我在那里的任何其他内容。
7- 调试.打印:
Debug.Print rng.AutoFilter; 1, Me.DashboardBudgetlst.Column(1, i)
在列表框中选择差旅费用返回立即窗口:
True 1 Travel Expenses
8-一些屏幕截图:
它的工作原理就像我关闭错误后过滤器将应用一样。但是我想知道是否还有其他解决方法,并且我不确定是否使用“On Error Resume Next”(这对您的代码有害吗?)
最佳答案
我能够重复该错误
根据列表框中选择的项目数量,问题似乎是触发了多个 _Change
事件
我能够通过使用事件标志来停止错误
<小时/>Option Explicit
Private Sub DashboardBudgetlst_Change()
Dim rng As Range, i As Long, lstItm As String, crit As String, startIndex As Long
If Application.EnableEvents = False Then Exit Sub 'If flag is Off exit Sub
Application.EnableEvents = False 'Turn flag Off
With Me.DashboardBudgetlst
i = .ListIndex
If i >= 0 Then
If .Selected(i) And .Column(0, i) <> "" Then
Set rng = Budget.Range("B1:E5") ' & lrow(Budget, "A"))
rng.AutoFilter 1, .Value
End If
End If
End With
Application.EnableEvents = True 'Turn flag back On
End Sub
<小时/>
关于vba - 如何使用 VBA 过滤另一个工作表中的范围而不激活工作表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49724358/
我目前正在使用发现的重力脚本 here为了在我的网页上创建重力效果,我正在本地开发 atm。 我的问题是,重力效果的激活似乎是在鼠标移动时进行的,而我需要它在文档准备好时才触发。 google.cod
我正在尝试关注 Railsbridge Intallfest 并尝试将我的第一个 Rails 应用程序部署到 heroku。我不断收到以下错误消息: Gem::LoadError: Specified
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
Home-tab 是默认选中的,但是它的颜色是灰色的:( Home Bla Contact
我没有得到它的工作,我不知道为什么......遗憾的是其他问题 + 答案没有帮助。 测试设备: iPhone 6 iPad 2 相关代码: override func viewWillTransiti
我试图加载一个 View ,就像用户已经按下 UISearchBar 一样。我希望 SearchController 加载顶部的 UISearchBar 以及取消按钮。 我已经试过了: func ac
试图在 if whiteDotDist < centerRadius - whiteDotRadius 时获取代码执行它下面的所有代码都是事件的,并且当它下面的代码被执行时它再次变为非事件状态直到if
我正在使用 anaconda python。所以每次,在我的 mac 终端中,我输入终端命令: source /Users/mylaptop/anaconda/bin/activate /Users/
在我的 Angular 项目中,我有这种代码: this.swUpdate.available.subscribe(() => { ... }); 它工作正常,但给了我关于 activated 被
我想弄清楚 Julia 包是如何工作的,因为我喜欢容器化环境。我真的很挣扎。 在 python 中,我会做类似 conda create env --name ds 的事情创建环境然后安装容器化包我会
我的宏中有一些代码如下 ChDir File_pth Workbooks.Open filename:= File_pth & "\" & open_tkt Workbooks.Open filena
长话短说,我有两张纸,一张是“原始数据”,另一张是“结果”。我试图让结果表从“原始数据”表的每第七行中提取文本或数字,因此“结果”中的 A1 将是原始数据中的 A1,“结果”中的 A2 将是“原始数据
我不知道如何做到这一点,或者我是否可以做到这一点。我有一个 jQuery UI Accordion,多个部分,每个部分包含多个 anchor 标记,每个 anchor 标记都有一个唯一的字符串 id。
我不敢相信我还没有找到任何关于此的文档,但我想知道如何命令键盘激活并接收来自它的输入。我可以找到在编辑文本字段时操作弹出键盘的所有示例。谢谢 最佳答案 您还可以使用 UIKeyInput 协议(pro
我正在尝试为我的 Electron 应用程序生成NSIS安装程序的日志。为此,我创建了一个文件'logging.nsh'来定义LogSet和LogText宏。 以下是logging.nsh文件的代码:
几周前,我开始使用 typescript 和 knockoutJS,我有一个具体的问题,但我有解决方案,它太丑了,我无法忍受,但无法从中得到任何更好的东西,有太多代码需要粘贴,但我会尽力描述我的问题:
当我尝试激活我的虚拟环境时收到此错误即源 ~/edu-venv/bin/activate -bash: /home/vagrant/edu-venv/bin/activate: No such fil
要创建触发器,似乎必须发布它才能生效。但是发布需要对“协作”分支进行 PR,这意味着我们甚至在测试触发器是否实际工作之前就必须创建一个 PR,并且还必须创建多个后续 PR,直到我们获得正确的触发器。
我是最近的 IntelliJ Idea 用户,我不知道如何启用 Hibernate。当我右键单击我的项目时,Hibernate 不会出现在“添加框架支持”菜单中(实际上我唯一可以选择的技术是 Groo
要创建触发器,似乎必须发布它才能生效。但是发布需要对“协作”分支进行 PR,这意味着我们甚至在测试触发器是否实际工作之前就必须创建一个 PR,并且还必须创建多个后续 PR,直到我们获得正确的触发器。
我是一名优秀的程序员,十分优秀!