Excel 自动执行全局宏

Excel 自动执行全局宏 25.04.09

步骤 1:创建个人宏工作簿(Personal.xlsb)

  1. 生成Personal.xlsb

    (如尚未存在):

    • 打开Excel → 开发工具 → 录制宏 → 选择"保存到个人宏工作簿" → 停止录制。
    • Alt + F11 进入VBA编辑器,确认左侧出现 PERSONAL.XLSB

步骤 2:在Personal.xlsb中设置全局事件监听

  1. 插入类模块

    • 右键点击 PERSONAL.XLSB → 插入 → 类模块 → 重命名为 clsAppEvents

    • 在类模块中输入以下代码:

      vba 复制代码
      Public WithEvents App As Application  ' 声明应用程序级事件
      
      ' 当任何工作簿被打开时触发
      Private Sub App_WorkbookOpen(ByVal Wb As Workbook)
          On Error Resume Next  ' 防止错误中断
          Call YourGlobalMacro(Wb)  ' 传递当前打开的工作簿对象
      End Sub
  2. 绑定事件到Application对象

    • 双击PERSONAL.XLSB下的ThisWorkbook

      → 输入代码:

      vba 复制代码
      Private myAppHandler As clsAppEvents  ' 声明类实例
      
      ' 当Personal.xlsb加载时绑定事件
      Private Sub Workbook_Open()
          Set myAppHandler = New clsAppEvents  ' 初始化类
          Set myAppHandler.App = Application  ' 绑定到全局Application对象
      End Sub

步骤 3:编写全局宏

  1. 在Personal.xlsb中插入模块:

    • 右键插入新模块 → 输入以下代码:

      vba 复制代码
      Sub YourGlobalMacro(Wb As Workbook)
          MsgBox "检测到工作簿被打开:" & Wb.Name, vbInformation
          ' 示例:在所有工作簿中自动执行操作
          Wb.Sheets(1).Range("A1").Value = "AutoMacro Executed!"
          
          If Wb.Name <> "PERSONAL.XLSB" Then
              With ActiveWindow
                  .SplitRow = 3    ' 分割线在第1行下方
                  .SplitColumn = 1
                  .FreezePanes = True  ' 冻结窗格
              End With
              
              ' 或调整指定区域的列宽(例如A到C列)
              Range("A:Z").Columns.AutoFit
          End If
      End Sub
      
      // 版本2 
      Sub YourGlobalMacro(Wb As Workbook)
          'MsgBox "检测到工作簿被打开:" & Wb.Name, vbInformation
          ' 示例:在所有工作簿中自动执行操作
          'Wb.Sheets(1).Range("A1").Value = "AutoMacro Executed!"
          
          If Wb.Name <> "PERSONAL.XLSB" Then
              With ActiveWindow
                  .SplitRow = 3    ' 分割线在第1行下方
                  .SplitColumn = 1
                  .FreezePanes = True  ' 冻结窗格
              End With
              
              Call AutoFitSelectionWithMaxWidth
             
          End If
          
          
      End Sub
      
      
      Sub AutoFitSelectionWithMaxWidth()
          Dim maxWidth As Double
          maxWidth = 100
          
           ' 或调整指定区域的列宽(例如A到C列)
          Range("A:Z").Columns.AutoFit
              
         
             
          For Each col In Range("A:Z").Columns
              If col.ColumnWidth > maxWidth Then
                  col.ColumnWidth = maxWidth
              End If
          Next col
          
      End Sub

步骤 4:保存并验证

  1. 保存到XLSTART文件夹:

    • 按Ctrl + S→ 确保路径为:

      复制代码
      C:\Users\<用户名>\AppData\Roaming\Microsoft\Excel\XLSTART\PERSONAL.XLSB
  2. 重启Excel并测试:

    • 关闭所有Excel窗口,重新打开Excel。
    • 新建或打开任意Excel文件(如Test.xlsx):
      • 应弹出消息框显示文件名,且A1单元格被写入内容。

步骤 5:导出给其他人使用

复制 PERSONAL.XLSB ,可以给其他人使用,放入用户 对应目录下:

C:\Users<用户名>\AppData\Roaming\Microsoft\Excel\XLSTART

相关推荐
weixin_443290695 小时前
【脚本系列】如何使用 Python 脚本对同一文件夹中表头相同的 Excel 文件进行合并
开发语言·python·excel
谢尔登6 小时前
office-ai整合excel
人工智能·excel
djk88886 小时前
.net winfrom 获取上传的Excel文件 单元格的背景色
excel
水...琥珀8 小时前
【日常技能】excel的vlookup 匹配#N/A
excel
流形填表1 天前
AI 助力:如何批量提取 Word 表格字段并导出至 Excel
开发语言·人工智能·word·excel·办公自动化
Smilecoc1 天前
Excel快捷键
excel
开开心心就好1 天前
AI抠图软件,本地运行超快速
网络·人工智能·网络协议·tcp/ip·docker·电脑·excel
努力的小郑1 天前
从 OOM 到秒级导入:EasyExcel 百万级数据优化实战(附可直接跑的工具类)
spring boot·excel
01传说1 天前
JAVA ---Excel高效导入(去重1000万数据对比)
android·java·excel
Lo-Y-eH2 天前
Openpyxl:Python操作Excel的利器
python·excel