小编致力于为大家奉献最有效的经验,让大家能够解决掉问题,但是大家也都知道,每个人遇到的情况都是不一样的,大家在看小编经验的同时,除了跟随操作,也需要自己的思考,举一反三的解决问题,这样才会变得更加有内涵,成为和小编一样的经验达人。excel中使用vba来移动窗口位置,这里,让小编给大家介绍一下。

工具/原料
- excel2016
- 此经验本人原创首发,未经本人许可请勿转载。
方法/步骤
- 1
首先我们打开一个工作样表作为例子。
- 2
使用alt+f11组合快捷键进入vbe编辑器,插入一个新的模块,并在模块中输入以下代码:
Sub SetWindowPosition()
Dim iTop As Long, iLeft As Long
MsgBox "将当前窗口向下移60,向右移90"
ActiveWindow.WindowState = xlNormal
iTop = ActiveWindow.Top
iLeft = ActiveWindow.Left
ActiveWindow.Top = iTop + 60
ActiveWindow.Left = iLeft + 90
MsgBox "恢复原来窗口的位置"
ActiveWindow.Top = iTop
ActiveWindow.Left = iLeft
End Sub
- 3
我们先确认一件事,当前窗口的坐标位置是以左上角为起始点,也就是一个屏幕左方的left横坐标,和一个屏幕上方top纵坐标,因此设置屏幕的位置就需要这两个坐标一起确认。
- 4
需要注意的是,当前窗口在窗口处于最小化和最大化的时候,是无法进行窗口属性的设置的,必须是正常显示的状态。也就是ActiveWindow.WindowState = xlNormal
- 5
left属性和top属性是一个数值,我们声明其作用为数值,这样可以使用运算符进行运算增加或减少left值和top值达到移动窗口的目的。
- 6
ActiveWindow.Top和ActiveWindow.left是窗口初始值,预先设定一个变量储存这个值,可以在后面移动窗口后恢复原来初始位置。
- 7
先写到这里了,谢谢大家的观看。
祝大家生活愉快。
小编还有许多其他的经验可以观看,如果无法解决问题可以联系小编进行咨询。
看不清楚图片的可以点击放大再看哦。
END
注意事项
- 个人经验,仅供参考。