VBA如何实现隐藏、显示工作表

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了VBA如何实现隐藏、显示工作表相关的知识,希望对你有一定的参考价值。

工作薄里有6个工作表,我想打开时只显示第一个工作表,其余的为隐藏,需要时再全部显示出现来,需制作二个按纽,一个为隐藏、一个为显示!

若要做成两个按纽,您可以这样做:
‧于[表01]分别建立两个相应的功能按钮。
‧复制以下代码并黏贴至[ThisWorkbook]代码区:
Private Sub Workbook_Open()
Call yyABshtsHIDDEN
End Sub
‧复制以下代码并黏贴至[主要模组]代码区:
Sub yyAAshtsVISIBLE()
Call yyBAshtsVISI(0)
End Sub
Sub yyABshtsHIDDEN()
Call yyBAshtsVISI(1)
End Sub
Sub yyBAshtsVISI(ByVal yiOPC As Integer)
Dim yiACA As Integer
For yiACA = 2 To Sheets.Count
Sheets(yiACA).Visible = IIf(yiOPC = 0, xlSheetVisible, xlSheetHidden)
Next yiACA
Sheets(1).Activate
Range("A1").Activate
End Sub

您还可以这样做:
‧可将[xlSheetHidden(隐藏)]改为[xlSheetVeryHidden(特别隐藏)]。
‧可将两个按钮并为一个按钮。
参考技术A Option Explicit

Sub xxx()
    Sheet2.Visible = xlSheetHidden
    Sheet1.Visible = xlSheetVisible
End Sub


上面的例子代码隐藏Sheet2、显示Sheet1,你参考一下,我相信你能实现你的目的,有问题请追问。

使用Excel VBA,如何将某一个工作表保存到新建的Excel中?

1、如下图所示,我想将桌面上第一章中的每个工作簿名称放置到工作表中。

2、新建一个工作簿,将其命名为“第一章目录”,按alt+f11组合键,打开宏界面。

3、在VBA中,单击插入按钮,点击插入菜单下的模块,即可新建模块,系统默认为模块1,当然也可以根据需要重命名。

4、使用do~~loop循环语句,在VBA中输入如下图所示代码:

5、返回名为“第一章目录”的工作簿中,按alt+f8组合键,弹出宏对话框。

6、点击宏对话框中的执行按钮,宏对话框自动关闭,代码自动执行,即第一章中的每个文件夹名称全部显示在工作表sheet1中。最后根据自己的需要调整格式。

参考技术A 代码如下:
Sub 分开存为工作薄()

Dim Sh As Worksheet
Dim Wk1 As Workbook
Dim Wk2 As Workbook
Dim iPath As String

Application.ScreenUpdating = False ‘将屏幕更新关闭
Application.DisplayAlerts = False

iPath = ThisWorkbook.Path & "\" '保存路径为当前工作簿所在路径
Set Wk1 = Workbooks.Add
Set Wk2 = Workbooks.Add
Wk1.SaveAs iPath & "部门" & ".xls"
Wk2.SaveAs iPath & "基层" & ".xls"
'将工作表分别复制到部门或基层工作薄中
For Each Sh In ThisWorkbook.Worksheets
With Sh
If .Name Like "*部门*" Then
.Copy before:=Workbooks("部门").Worksheets("sheet1")
ElseIf .Name Like "*基层*" Then
.Copy before:=Workbooks("基层").Worksheets("sheet1")
Else
MsgBox "工作表" & .Name & "不含有部门或基层"
End If
End With
Next
'删除新建工作薄时默认新建的工作表
For Each Sh In Wk1.Worksheets
With Sh
If .Name Like "*Sheet*" Then
.Delete
End If
End With
Next
For Each Sh In Wk2.Worksheets
With Sh
If .Name Like "*Sheet*" Then
.Delete
End If
End With
Next
'保存部门和基层工作薄
Wk1.Save
Wk2.Save
Wk1.Close
Wk2.Close
Set Wk1 = Nothing
Set Wk2 = Nothing
Application.DisplayAlerts = True
Application.ScreenUpdating = True
End Sub
其中Application.DisplayAlerts、 Application.ScreenUpdating 语句把过程中的无必要的警告都删除了,像在删除多余的工作表时会提示“数据可能在你要删除的工作表中,请问是否要删除”等等的警告,在写程序的过程中可以写不加人,有利于了解工程是怎么运作的,但是最后还是加上这两句比较好,否则用户使用时太多的警告信息感觉不是很好。
.Copy before:=Workbooks("基层").Worksheets("sheet1")
此句是拷贝sheet到新的xls里,由于使用了with语句,前面的workbook的信息省略了,但是有copy before与copy after注意选择,具体区别自己也不是很清楚。Workbooks("基层").Worksheets("sheet1")拷贝到基层.xls的sheet1里,但是看到下面删除sheet时并没有把此表分别开,会不会出错?
以下是我自己的程序:
Set sht = newbk.Worksheets(1) '删除新建的newbk里的两个sheet,必须留一个,否则会出错
sht.Delete
Set sht = newbk.Worksheets(1)
sht.Delete
oldbk.Worksheets(sSheetName).Copy After:=newbk.Worksheets(1) '拷贝
Set sht = newbk.Worksheets(1) ’删除一个工作表,会删错么?
sht.Delete
newbk.Worksheets(1).Name = sSheetName
newbk.Save
拷贝处选用的是Worksheets(1),本想用Worksheets(sSheetName),但是系统出错,应该是新xls中没有此sheet,只有默认的1、2、3,所以出错。
对删除工作表的操作表示疑问,因为怕删错,Worksheets(1)是选择当前最前端的窗口,此程序测试正确,那么应该是新生成的没有作为active?
===============================================
所以拷贝时有3个问题:
1、copy before 与copy after的区别?
2、copy后新的名称是什么?
3、copy后的表是不是最前端的?

从网上看到的,可以对第一个问题很好的解释:
Sheets("mainREPORT").Copy Before:=Sheets(4)
after:是将表mainreport创建拷贝到‘4’表的后面
before:是将表mainreport创建拷贝到‘4’表的前面
是一个位置的问题

以上是关于VBA如何实现隐藏、显示工作表的主要内容,如果未能解决你的问题,请参考以下文章

如何隐藏 excel 表单

excel等于某个值自动 隐藏/显示 整行 求教VBA代码

如何阻止某人取消隐藏我的 Excel 工作表?

vba实现跨工作簿之间单元格录入数据的方法

VBA 如何批量将单元格复制到另一个工作表中

vba在打开时显示用户表单,隐藏工作表,但保留任务栏图标