ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 效率神器,一键搞定繁琐工作
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
让更多数据处理,一键完成 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 9418|回复: 7

[转帖] excel-窗口(Window对象)基本操作应用示例

[复制链接]

TA的精华主题

TA的得分主题

发表于 2009-8-15 16:59 | 显示全部楼层 |阅读模式
http://www.excelba.com/Art/Html/183.html

Window对象代表一个窗口,约有48个属性和14个方法,能对窗口特性进行设置和操作。Window对象是Windows集合中的成员,对于Application对象来说,Windows集合包含该应用程序中的所有窗口;对于Workbook对象来说,Windows集合只包含指定工作簿中的窗口。下面介绍一些示例,以演示和说明Window对象及其属性和方法的运用。

--------------------------------------------------------------------------------
示例02-01:激活窗口(Activate方法)
Sub SelectWindow()
  Dim iWin As Long, i As Long, bWin
  MsgBox "依次切换已打开的窗口"
  iWin = Windows.Count
  MsgBox “您已打开的窗口数量为:” & iWin
  For i = 1 To iWin
    Windows(i).Activate
    bWin = MsgBox("您激活了第 " & i & "个窗口,还要继续吗?", vbYesNo)
    If bWin = vbNo Then Exit Sub
  Next i
End Sub

--------------------------------------------------------------------------------
示例02-02:窗口状态(WindowState属性)
[示例02-02-01]
Sub WindowStateTest()
  MsgBox "当前活动工作簿窗口将最小化"
  Windows(1).WindowState = xlMinimized
  MsgBox "当前活动工作簿窗口将恢复正常"
  Windows(1).WindowState = xlNormal
  MsgBox "当前活动工作簿窗口将最大化"
  Windows(1).WindowState = xlMaximized
End Sub
示例说明:使用WindowState属性可以返回或者设置窗口的状态。示例中,常量xlMinimized、xlNormal和xlMaximized分别代表窗口不同状态值,Windows(1)表示当前活动窗口。可以使用Windows(index)来返回单个的Window对象,其中的index为窗口的名称或编号,活动窗口总是Windows(1)。
[示例02-02-02]
Sub testWindow()
  '测试Excel应用程序窗口状态
  MsgBox "应用程序窗口将最大化"
  Application.WindowState = xlMaximized
  Call testWindowState
  MsgBox "应用程序窗口将恢复正常"
  Application.WindowState = xlNormal
  MsgBox "应用程序窗口已恢复正常"
    '测试活动工作簿窗口状态
    MsgBox "当前活动工作簿窗口将最小化"
    ActiveWindow.WindowState = xlMinimized
    Call testWindowState
    MsgBox "当前活动工作簿窗口将最大化"
    ActiveWindow.WindowState = xlMaximized
    Call testWindowState
    MsgBox "当前活动工作簿窗口将恢复正常"
    ActiveWindow.WindowState = xlNormal
    Call testWindowState
  MsgBox "应用程序窗口将最小化"
  Application.WindowState = xlMinimized
  Call testWindowState
End Sub
‘*********************************************************
Sub testWindowState()
  Select Case Application.WindowState
    Case xlMaximized: MsgBox "应用程序窗口已最大化"
    Case xlMinimized: MsgBox "应用程序窗口已最小化"
    Case xlNormal:
      Select Case ActiveWindow.WindowState
        Case xlMaximized: MsgBox "当前活动工作簿窗口已最大化"
        Case xlMinimized: MsgBox "当前活动工作簿窗口已最小化"
        Case xlNormal: MsgBox "当前活动工作簿窗口已恢复正常"
      End Select
  End Select
End Sub
示例说明:本示例有两个程序,其中testWindow()是主程序,调用子程序textWindowState(),演示了应用程序窗口和工作簿窗口的不同状态。当前活动窗口一般代表当前活动工作簿窗口,读者可以在VBE编辑器中按F8键逐语句运行testWindow()程序,观察Excel应用程序及工作簿窗口的不同状态。此外,在子程序中,还运用了嵌套的Select Case结构。
[示例02-02-03]
Sub SheetGradualGrow()
  Dim x As Integer
  With ActiveWindow
    .WindowState = xlNormal
    .Top = 1
    .Left = 1
    .Height = 50
    .Width = 50
    For x = 50 To Application.UsableHeight
      .Height = x
    Next x
    For x = 50 To Application.UsableWidth
      .Width = x
    Next x
    .WindowState = xlMaximized
  End With
End Sub
示例说明:本示例将动态演示工作簿窗口由小到大直至最大化的变化过程。在运行程序时,您可以将VBE窗口缩小,从而在工作簿中查看动态效果,也可以在Excel中选择菜单中的宏命令执行以查看效果。

--------------------------------------------------------------------------------
示例02-03:切换显示工作表元素
[示例02-03-01]
Sub testDisplayHeading()
  MsgBox “切换显示/隐藏行列标号”
  ActiveWindow.DisplayHeadings = Not ActiveWindow.DisplayHeadings
End Sub
示例说明:本示例切换是否显示工作表中的行列标号。运行后,工作表中的行标号和列标号将消失;再次运行后,行列标号重新出现,如此反复。您也可以将该属性设置为False,以取消行列标号的显示,如ActiveWindow.DisplayHeadings = False;而将该属性设置为True,则显示行列标号。
[示例02-03-02]
Sub testDisplayGridline()
  MsgBox “切换显示/隐藏网格线”
  ActiveWindow.DisplayGridlines = Not ActiveWindow.DisplayGridlines
End Sub
示例说明:本示例切换是否显示工作表中的网格线。运行后,工作表中的网格线消失,再次运行后,网格线重新出现,如此反复。您也可以将该属性设置为False,以取消网格线显示,如ActiveWindow.DisplayGridlines = False;而将该属性设置为True,则显示网格线。
[示例02-03-03]
Sub DisplayHorizontalScrollBar()
  MsgBox “切换显示/隐藏水平滚动条”
  ActiveWindow.DisplayHorizontalScrollBar =  _
   Not ActiveWindow.DisplayHorizontalScrollBar
End Sub
示例说明:本示例切换是否显示工作表中的水平滚动条。运行后,工作表中的水平滚动条消失,再次运行后,水平滚动条重新出现,如此反复。您也可以将该属性设置为False,以取消水平滚动条,如ActiveWindow.DisplayHorizontalScrollBar = False;而将该属性设置为True,则显示水平滚动条。
同理,DisplayVerticalScrollBar属性将用来设置垂直滚动条。
[示例02-03-04]
Sub DisplayScrollBar()
  MsgBox "切换显示/隐藏水平和垂直滚动条"
  Application.DisplayScrollBars = Not (Application.DisplayScrollBars)
End Sub
示例说明:本示例切换是否显示工作表中的水平和垂直滚动条。运行后,工作表中的水平和垂直滚动条同时消失,再次运行后,水平和垂直滚动条重新出现,如此反复。您也可以将该属性设置为False,以取消水平和垂直滚动条显示,如Application.DisplayScrollBars= False;而将该属性设置为True,则显示水平和垂直滚动条。

--------------------------------------------------------------------------------
示例02-04:显示公式(DisplayFormulas属性)
Sub DisplayFormula()
  MsgBox “显示工作表中包含公式的单元格中的公式”
  ActiveWindow.DisplayFormulas = True
End Sub
示例说明:本程序运行后,工作表中含有公式的单元格将显示公式而不是数值。若要显示数值,则将该属性设置为False,或者,如果工作表中的公式显示的是结果数值,则该属性为False。

--------------------------------------------------------------------------------
示例02-05:显示/隐藏工作表标签(DisplayWorkbookTabs属性)
Sub testDisplayWorkbookTab()
  MsgBox “隐藏工作表标签”
  ActiveWindow.DisplayWorkbookTabs = False
End Sub
示例说明:本程序运行后,工作表标签消失。将该属性设置为True,重新显示工作表标签。

--------------------------------------------------------------------------------
示例02-06:命名活动窗口(Caption属性)
Sub testCaption()
  MsgBox "当前活动工作簿窗口的名字是:" & ActiveWindow.Caption
  ActiveWorkbook.Windows(1).Caption = "我的工作簿"
  MsgBox "当前活动工作簿窗口的名字是:" & ActiveWindow.Caption
End Sub
示例说明:本程序运行后,显示当前活动工作簿窗口原先的名称(即工作簿窗口未处于最大化状态时,出现在窗口顶部标题栏中的文字),然后设置当前活动工作簿窗口名称,即使用语句ActiveWorkbook.Windows(1).Caption = "我的工作簿",最后显示当前活动工作簿窗口的新名称。改变窗口的标题并不会改变工作簿的名称。

--------------------------------------------------------------------------------
示例02-07:移动窗口到指定位置(ScrollRow属性和ScrollColumn属性)
Sub testScroll()
  MsgBox “将当前窗口工作表左上角单元格移至第10行第3列”
  ActiveWindow.ScrollRow = 10
  ActiveWindow.ScrollColumn = 3
End Sub
示例说明:本程序运行后,当前活动窗口左上角单元格为第10行第3列。可以通过设置这两个属性来移动窗口到指定的位置,也可以返回指定窗格或窗口最左上面的行号或列号。

--------------------------------------------------------------------------------
[NextPage] 示例02-08:调整窗口(EnableResize属性)
Sub testResize()
  MsgBox “设置窗口大小不可调整”
  ActiveWindow.EnableResize = False
End Sub
示例说明:测试本程序前,将当前工作簿窗口恢复为正常状态(即让工作簿标题可见),运行程序后,当前工作簿窗口将不能调整其大小,右上角的最小化最大化按钮将消失(即隐藏最大化和最小化按钮)。该属性设置为True,则能调整窗口大小。

--------------------------------------------------------------------------------
示例02-09:拆分窗格
[示例02-09-01]
Sub SplitWindow1()
  Dim iRow As Long, iColumn As Long
  MsgBox "以活动单元格为基准拆分窗格"
  iRow = ActiveCell.Row
  iColumn = ActiveCell.Column
  With ActiveWindow
    .SplitColumn = iColumn
    .SplitRow = iRow
  End With
  MsgBox "恢复原来的窗口状态"
  ActiveWindow.Split = False
End Sub
[示例02-09-02]
Sub SplitWindow()
  Dim iRow As Long, iColumn As Long
  MsgBox "以活动单元格为基准拆分窗格"
  iRow = ActiveCell.Row
  iColumn = ActiveCell.Column
  With ActiveWindow
    .SplitColumn = iColumn
    .SplitRow = iRow
  End With
  MsgBox "恢复原来的窗口状态"
  ActiveWindow.SplitColumn = 0
  ActiveWindow.SplitRow = 0
End Sub
示例说明:本示例演示了以活动单元格为基准拆分窗格。如果指定窗口被拆分,则Split属性的值为True;设置该属性的值为False则取消窗格拆分。也可以设置SplitColumn属性和SplitRow属性的值来取消窗格拆分。

--------------------------------------------------------------------------------
示例02-10:冻结窗格(FreezePanes属性)
Sub testFreezePane()
  MsgBox “冻结窗格”
  ActiveWindow.FreezePanes = True
End Sub
示例说明:运行本程序后,将会冻结活动单元格所在位置上方和左侧的单元格区域。将该属性的值设置为False,将取消冻结窗格。

--------------------------------------------------------------------------------
示例02-11:设置网格线颜色(GridlineColor属性和GridlineColorIndex属性)
Sub setGridlineColor()
  Dim iColor As Long
  iColor=ActiveWindow.GridlineColor
  MsgBox "将活动窗口的网格线颜色设为红色"
  ActiveWindow.GridlineColor = RGB(255, 0, 0)
  MsgBox "将活动窗口的网格线颜色设为蓝色"
  ActiveWindow.GridlineColorIndex = 5
  MsgBox “恢复为原来的网格线颜色”
  ActiveWindow.GridlineColorIndex=iColor
End Sub
示例说明:运行程序后,当前工作表窗口网格线将被设置为红色。其中,GridlineColorIndex属性可以用于返回或设置网格线的颜色,下面给出了默认调色板中颜色的编号值:

[小结]ActiveWindow属性返回当前激活的工作簿窗口,可以用来设置工作表中的元素,也可以显示特定的单元格,或者用来调整窗口的显示比例,以及设置窗口。
示例02-12:设置工作表标签区域宽度和水平滚动条宽度比例(TabRatio属性)
Sub test()
  MsgBox "设置工作表标签区域宽度为水平滚动条宽度的一半"
  ActiveWindow.TabRatio = 0.5
End Sub
示例说明:TabRatio属性返回或设置工作簿中工作表标签区域的宽度与窗口水平滚动条的宽度比例(可为0到1之间的数字;默认值为0.6)。您可以改变上面程序中的数值进行测试。

--------------------------------------------------------------------------------
示例02-13:设置激活窗口时运行的程序(OnWindow属性)
Sub testRunProcedure()
  ThisWorkbook.Windows(1).OnWindow = "test"
End Sub
‘*********************************************************
Sub test()
  MsgBox "您可以使用本窗口了!"
End Sub
示例说明:本示例包括两个程序,主程序为testRunProcedure(),运行后,每当激活该窗口时,将会运行test()程序。其中,OnWindow属性返回或设置每当激活一个窗口时要运行的过程的名称,如本例中的test()程序。

--------------------------------------------------------------------------------
示例02-14:获取指定窗口单元格区域地址(RangeSelection属性)
Sub testRangeSelection()
  MsgBox "显示所选单元格地址"
  MsgBox ActiveWindow.RangeSelection.Address
End Sub
示例说明:本示例返回当前窗口中所选单元格区域的地址。RangeSelection属性返回指定窗口的工作表中的选定单元格(即使指定工作表中有图形对象处于活动状态,或者已选定图形对象,仍返回在图形对象被选定之前选定的单元格区域,这是该属性与Selection属性的区别)。

--------------------------------------------------------------------------------
[NextPage] 示例02-15:返回指定窗口中所选择的工作表(SelectedSheets属性)
Sub testSelectedSheet()
  Dim sh As Worksheet
  For Each sh In ActiveWorkbook.Windows(1).SelectedSheets
    MsgBox "工作表" & sh.Name & "被选择"
  Next
End Sub
示例说明:SelectedSheets属性返回代表指定窗口中的所有选定工作表的集合。本示例中,如果您同时选择了活动工作簿中的工作表Sheet1和Sheet2,那么运行程序后,将会显示相应工作表被选择的信息。

--------------------------------------------------------------------------------
示例02-16:排列窗口(Arrange方法)
Sub testArrangeWindows()
  MsgBox "请确保应用程序至少含有两个工作簿,这样才能看出效果"
  MsgBox “窗口将平铺显示”
  Windows.Arrange ArrangeStyle:=xlArrangeStyleTiled
  MsgBox “窗口将层叠显示”
  Windows.Arrange ArrangeStyle:=xlArrangeStyleCascade
  MsgBox “窗口将水平排列显示”
  Windows.Arrange ArrangeStyle:=xlArrangeStyleHorizontal
  MsgBox “窗口将垂直并排排列显示”
  Windows.Arrange ArrangeStyle:=xlArrangeStyleVertical
End Sub
示例说明:运行本程序后,将平铺应用程序中的所有窗口。Arrange方法用于对屏幕上的窗口进行排列,其语法为expression.Arrange(ArrangeStyle, ActiveWorkbook, SyncHorizontal, SyncVertical),所有的参数均为可选参数。其中,参数ArrangeStyle代表排列样式,可为以下常量:常量xlArrangeStyleTiled为缺省值,表示将平铺窗口;常量xlArrangeStyleCascade表示将窗口进行层叠;常量xlArrangeStyleHorizontal表示将水平排列所有窗口;常量xlArrangeStyleVertical表示将垂直并排排列所有窗口。您可以在上面的程序中测试这些常量,以体验效果。将参数ActiveWorkbook设置为True,则只对当前工作簿的可见窗口进行排列。如果为False,则对所有窗口进行排列。默认值为 False。设置参数SyncHorizontal为True,在水平滚动时同步滚动当前工作簿的所有窗口;如果为 False,则不同步滚动。设置参数SyncVertical为True,则在垂直滚动时同步滚动当前工作簿的所有窗口;如果为 False,则不同步滚动,默认值为 False。如果参数ActiveWorkbook为False或者省略,则参数SyncHorizontal和SyncVertical被忽略。

--------------------------------------------------------------------------------
示例02-17:窗口尺寸(UsableHeight、UsableWidth、Height、Width属性)
Sub testActiveWindowSize()
MsgBox "当前窗口可用区域的高度为:" & ActiveWindow.UsableHeight
   MsgBox "当前窗口的高度为:" & ActiveWindow.Height
   MsgBox "当前窗口可用区域的宽度为:" & ActiveWindow.UsableWidth
   MsgBox "当前窗口的宽度为:" & ActiveWindow.Width
End Sub

其它见原帖 窗口(Window对象)基本操作应用示例.rar (14.95 KB, 下载次数: 239)

[ 本帖最后由 ningyong58 于 2009-8-15 17:05 编辑 ]

评分

1

查看全部评分

TA的精华主题

TA的得分主题

发表于 2009-8-15 17:30 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2013-11-5 15:00 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2015-3-29 23:20 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
很全,很详细,感谢楼主分享

TA的精华主题

TA的得分主题

发表于 2018-2-21 23:33 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2018-11-18 10:15 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2019-5-26 10:39 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
实用教程,感谢分享

TA的精华主题

TA的得分主题

发表于 2024-8-28 12:47 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
大佬,还混论坛吗,求教一下:

当前的工作簿有工作表1、工作表2、工作表3,想要在工作表1为当前工作表的情况下,水平重排工作表1和工作表2(工作表2通过新建窗口实现),。但其他打开的工作簿(不特定,所以名称未知)也参与了窗口排列。
如何只让当前工作簿的工作表1、工作表2参与窗口排列?
目前有两个想法,一是重排窗口前,最小化其他非活动的工作簿;
二是重排指定名称的窗口,非指定的工作簿或工作表均被排除在外。

如何用VBA代码实现?
谢谢
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-11-18 17:23 , Processed in 0.049974 second(s), 10 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

快速回复 返回顶部 返回列表