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

相关推荐
码猩1 分钟前
C# winform根据EXCEL匹配文件后将txt的图片分别下载到指定的文件夹里
开发语言·c#·excel
焚 城28 分钟前
AI结合VBA提升EXCEL办公效率尝试
ai·excel
兰德里的折磨55032 分钟前
基于若依和elementui实现文件上传(导入Excel表)
前端·elementui·excel
唐骁虎36 分钟前
Excel VBA 运行时错误1004’:方法‘Open’作用于对象‘Workbooks’时失败 的解决方法
excel
weixin_4487717212 小时前
使用xml模板导出excel
xml·java·excel
杂学者1 天前
python 办公自动化------ excel文件的操作,读取、写入
python·excel
SunkingYang1 天前
C++中如何使用Cshapes类的addpicture函数将图片插入excel
excel·cshapes·addpicture·插入图片到excel·get_shapes
Eiceblue1 天前
使用Python写入JSON、XML和YAML数据到Excel文件
xml·开发语言·vscode·python·json·excel·pip
kurcp1 天前
vue3 antdesign上传解析excel
前端·typescript·excel
Excel_easy1 天前
表格开启聚光灯,查看数据不错行-Excel易用宝
excel