首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何为透视表筛选器捕获错误或防错子Workbook_SheetChange

如何为透视表筛选器捕获错误或防错子Workbook_SheetChange
EN

Stack Overflow用户
提问于 2017-07-01 04:46:39
回答 1查看 53关注 0票数 0

我需要一些帮助来捕获以下VBA代码的错误。这段代码很好地控制了2个透视表,从工作表上的单个单元格值中筛选出值。当该值未出现在筛选器中时,就会出现问题。我可以使用一种优雅的方式来简单地告诉用户,对于一个或两个透视表,该值不存在。

代码语言:javascript
复制
Private Sub Workbook_SheetChange(ByVal Sh As Object, ByVal Target As Range)
If Intersect(Target, Worksheets("Lookup").Range("A2")) Is Nothing Then Exit 
Sub

Dim pt1 As PivotTable
Dim pt2 As PivotTable
Dim Field1 As PivotField
Dim Field2 As PivotField
Dim NewCat1 As String
Dim NewCat2 As String

Set pt1 = Worksheets("Lookup").PivotTables("PTProd")
Set Field1 = pt1.PivotFields("Material Number End")
NewCat1 = Worksheets("Lookup").Range("A2").Value

Set pt2 = Worksheets("Lookup").PivotTables("PTClaim")
Set Field2 = pt2.PivotFields("Material")
NewCat2 = Worksheets("Lookup").Range("A2").Value

With pt
Field1.ClearAllFilters
Field1.CurrentPage = NewCat1
pt1.RefreshTable
Field2.ClearAllFilters
Field2.CurrentPage = NewCat2
pt2.RefreshTable
End With

End Sub
EN

回答 1

Stack Overflow用户

发布于 2017-07-01 04:58:06

我想你有很多方法可以做到这一点。这样的东西对你来说应该是有效的。

代码语言:javascript
复制
Sub HandleError()
' Your code here

On Error GoTo ErrMsg

Exit Sub

ErrMsg:
MsgBox ("Type in your message here."), , "MESSAGE TITLE"

End Sub

或者。。。

代码语言:javascript
复制
MsgBox Err.Description
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/44854606

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档