打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
打开工作簿后只显示用户窗体的方法探讨
除不断学习并分享新的文章外,将以前自认为好的文章慢慢捡起来,与大家共享,也存个档,呵呵……
问题起源
这是一位网友提出的问题:如何通过一个窗体录入数据,但是我又不想让人看到整个EXCEL工作薄。简单的说,就是打开某个EXCEL文件之后,我只看到一个窗体,然后我就通过该窗体录入数据,保存之后,所输入的数据就存在EXCEL文件里。
准备示例用户窗体
在VBE编辑器中,插入一个用户窗体,并在其中添加控件,如下图所示:

其相应的代码为:
Private Sub CommandButton1_Click()Dim i As Longi = Worksheets("sheet1").Range("A65536").End(xlUp).RowIf Range("A1") = "" ThenRange("A1") = TextBox1.TextElsei = i + 1Range("A" & i) = TextBox1.TextEnd IfTextBox1.Text = ""TextBox1.SetFocusEnd Sub

几种方法探讨
要使代码在工作簿打开时执行,则应利用Workbook_Open事件。一般应该将代码放置在ThisWorkbook模块中,这样在打开该工作簿时会执行其中的代码。
1、下面的代码,打开工作簿后,工作表均隐藏,只显示用户窗体,但Excel菜单和工具栏仍显示。

Private Sub Workbook_Open()UserForm1.ShowWorkbooks("Sample1.xls").Windows(1).Visible = FalseEnd Sub

详见示例Sample1.xls
2、下面的代码,在打开工作簿后,将只显示用户窗体。

Private Sub Workbook_Open()'最小化窗口  Application.WindowState = xlMinimized'显示用户窗体  UserForm1.ShowEnd Sub

若需在关闭用户窗体后,工作簿也随之前闭,则在用户窗体关闭事件中,添加下面的代码:

Private Sub UserForm_QueryClose(Cancel As Integer, CloseMode As Integer)ThisWorkbook.CloseEnd Sub

当关闭用户窗体时,Excel会提示用户是否保存对工作簿的修改,单击“是”将保存工作簿并退出。若要默认关闭用户窗体并自动保存工作簿,则添加下面的代码:

Private Sub UserForm_QueryClose(Cancel As Integer, CloseMode As Integer)ThisWorkbook.Close SaveChanges:=TrueEnd Sub

详见示例Sample2.xls
3、下面的示例代码,将彻底隐藏工作簿。在打开工作簿后,该工作簿将被隐藏,而只显示用户窗体,即将用户窗体当作用户输入界面,工作簿当作后台数据存储和处理。

Private Sub Workbook_Open()'隐藏工作簿    Application.Visible = False'显示用户窗体    UserForm1.ShowEnd Sub

详见示例Sample3.xls
注意:此时,Excel将在后台运行,要退出该Excel应用程序,必须结束其进程。

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
excel隐藏工作表界面只显示用户窗体的三种方法
问与答23:如何在打开工作簿后只显示用户窗体?
EXCEL登录系统
EXCEL VBA登录窗体设计
精彩的VBA代码第三十八讲:如何通过VBA代码隐藏Excel主窗口
Excel VBA 入门(2)
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服