当前位置: 首页 > article >正文

Excel VBA 入门到精通(一):宏录制与 VBE 环境详解

本章目标从零开始掌握 Excel VBA 开发环境的搭建理解宏录制原理并编写你的第一个 VBA 程序。一、什么是 VBAVBAVisual Basic for Applications是微软开发的嵌入式编程语言内置于 Office 套件中。它让 Excel 从静态表格工具进化为自动化数据处理平台。VBA 能做什么应用场景具体示例数据自动化批量导入 CSV、清洗数据、格式标准化报表生成自动汇总多表数据、生成图表、发送邮件界面定制创建交互式窗体、自定义功能区系统集成连接数据库、调用 API、与其他 Office 应用交互重复工作消除一键完成原本需要数小时的机械操作为什么要学 VBA零成本Excel 自带无需额外安装低门槛语法简单录制宏即可生成代码高效率几分钟的代码可替代数小时的手工操作强兼容与 Excel 深度集成操作表格如臂使指二、开启 VBA 开发之旅2.1 显示开发工具选项卡默认情况下Excel 隐藏了开发工具。按以下步骤开启Excel 2010/2013/2016/2019/365点击文件→选项选择自定义功能区右侧勾选开发工具点击确定┌─────────────────────────────────────────┐ │ Excel 选项 │ │ ┌──────────┬─────────────────────────┐ │ │ │ 常规 │ 自定义功能区 │ │ │ │ 公式 │ │ │ │ │ ... │ ☑ 开发工具 │ │ │ │ │ ☐ 加载项 │ │ │ └──────────┴─────────────────────────┘ │ └─────────────────────────────────────────┘2.2 认识开发工具选项卡开启后你会看到如下功能区┌────────────────────────────────────────────────────────────┐ │ 开发工具 │ │ ┌─────────┬─────────┬─────────┬─────────┬─────────┐ │ │ │ 代码组 │ 加载项组 │ 控件组 │ XML组 │ 修改组 │ │ │ │ │ │ │ │ │ │ │ │ [VB] │ │ [插入] │ │ │ │ │ │ [宏] │ │ [按钮] │ │ │ │ │ │ [录制宏]│ │ │ │ │ │ │ │ [安全性]│ │ │ │ │ │ │ └─────────┴─────────┴─────────┴─────────┴─────────┘ │ └────────────────────────────────────────────────────────────┘核心按钮说明按钮功能快捷键Visual Basic打开 VBE 编辑器Alt F11宏查看/运行已录制的宏Alt F8录制宏开始录制用户操作-安全性设置宏安全级别-三、宏录制零代码入门宏录制是 VBA 学习的最佳起点。它会将你的操作自动转换为 VBA 代码。3.1 录制第一个宏场景将 A1:C10 区域的数据加粗并设置黄色背景操作步骤开始录制点击开发工具→录制宏或使用快捷键点击状态栏左下角的录制按钮┌────────────────────────────────────┐ │ 录制新宏 │ │ ───────────────────────────────── │ │ 宏名称: FormatData │ │ 快捷键: Ctrl Shift F │ │ 保存在: 当前工作簿 │ │ 说明: 格式化数据区域 │ │ │ │ [确定] [取消] │ └────────────────────────────────────┘命名规范必须以字母开头只能包含字母、数字、下划线不能包含空格可用下划线代替不能使用 VBA 保留字如 Sub、Function执行操作选中 A1:C10 区域点击开始→加粗或Ctrl B点击填充颜色→黄色停止录制点击开发工具→停止录制或点击状态栏的停止按钮3.2 查看录制的代码按Alt F11打开 VBE你会看到Sub FormatData() FormatData 宏 格式化数据区域 Range(A1:C10).Select Selection.Font.Bold True With Selection.Interior .Pattern xlSolid .PatternColorIndex xlAutomatic .Color 65535 黄色 .TintAndShade 0 .PatternTintAndShade 0 End With End Sub代码解析代码行含义Sub FormatData()定义名为 FormatData 的子过程Range(A1:C10).Select选中 A1:C10 区域Selection.Font.Bold True将选中区域的字体设为粗体With Selection.Interior...设置选中区域的内部属性背景色End Sub子过程结束3.3 运行宏方法一通过宏对话框按Alt F8打开宏对话框选择FormatData点击运行方法二使用快捷键如果你在录制时设置了快捷键如Ctrl Shift F直接按快捷键即可方法三插入按钮开发工具→插入→按钮窗体控件在工作表上拖动绘制按钮在弹出的对话框中选择FormatData点击按钮即可运行宏四、VBE 环境深度解析VBEVisual Basic Editor是 VBA 的集成开发环境。熟练掌握它是高效编程的基础。4.1 VBE 界面布局┌──────────────────────────────────────────────────────────────┐ │ 菜单栏 [文件][编辑][视图][插入][格式][调试][运行][工具][外接程序][窗口][帮助] │ ├──────────────────────────────────────────────────────────────┤ │ 工具栏 [保存][剪切][复制][粘贴][运行][中断][重置][设计模式]... │ ├────────────────┬─────────────────────────────────────────────┤ │ │ │ │ 工程资源管理器 │ │ │ ┌──────────┐ │ 代码窗口 │ │ │ VBAProject│ │ ┌─────────────────────────────────────┐ │ │ │ ├─模块 │ │ │ Sub HelloWorld() │ │ │ │ ├─类模块 │ │ │ MsgBox Hello, VBA! │ │ │ │ └─UserForm│ │ │ End Sub │ │ │ │ Microsoft │ │ └─────────────────────────────────────┘ │ │ │ Excel对象 │ │ │ │ └──────────┘ │ │ │ │ │ │ 属性窗口 │ │ │ ┌──────────┐ │ │ │ │ 名称 │ │ │ │ │ 值 │ │ │ │ └──────────┘ │ │ │ │ │ └────────────────┴─────────────────────────────────────────────┘4.2 核心窗口详解工程资源管理器Project Explorer显示当前打开的所有 VBA 项目结构。快捷键Ctrl R┌─────────────────────────┐ │ 工程 - VBAProject │ ├─────────────────────────┤ │ 对象 │ │ └─ Sheet1 (Sheet1) │ │ └─ Sheet2 (Sheet2) │ │ └─ ThisWorkbook │ │ 模块 │ │ └─ 模块1 │ │ Microsoft Excel对象 │ │ └─ ... │ └─────────────────────────┘组件说明图标组件用途Excel 对象工作表和工作簿级别的事件代码模块通用的 Sub 和 Function类模块自定义对象进阶用户窗体交互式界面设计属性窗口Properties Window查看和修改选中对象的属性。快捷键F4┌─────────────────────────┐ │ 属性 - 模块1 │ ├─────────────────────────┤ │ (名称) 模块1 │ ├─────────────────────────┤ │ 按字母序 按分类序 │ ├─────────────────────────┤ │ 名称 模块1 │ └─────────────────────────┘代码窗口Code Window编写和编辑 VBA 代码的主战场。快捷键F7打开代码窗口F5运行当前过程F8逐语句调试F9设置/取消断点实用功能功能操作自动完成输入代码时按Ctrl 空格快速信息输入函数名后按Ctrl I对象浏览器按F2查看所有可用对象立即窗口按Ctrl G打开用于调试4.3 必备快捷键清单快捷键功能Alt F11Excel ↔ VBE 切换F5运行宏F8逐语句执行调试F9设置/取消断点Ctrl R显示工程资源管理器Ctrl G显示立即窗口Ctrl 空格自动完成Ctrl J列出属性/方法Ctrl I快速信息Ctrl Shift I参数信息五、编写你的第一个 VBA 程序5.1 Hello World在 VBE 中点击插入→模块在代码窗口输入Sub HelloWorld() MsgBox Hello, World!, vbInformation, 我的第一个宏 End Sub按F5运行你会看到一个消息框┌─────────────────────────┐ │ 我的第一个宏 │ ├─────────────────────────┤ │ │ │ Hello, World! │ │ │ │ [确定] │ │ │ └─────────────────────────┘5.2 与单元格交互Sub CellOperations() 向单元格写入数据 Range(A1).Value Hello VBA 读取单元格数据 Dim cellValue As String cellValue Range(A1).Value 显示读取的值 MsgBox A1单元格的值是: cellValue 格式化单元格 With Range(A1) .Font.Bold True .Font.Size 14 .Interior.Color RGB(255, 255, 0) 黄色 End With End Sub5.3 批量数据处理Sub BatchProcess() Dim i As Integer 在 A1:A10 填充数据 For i 1 To 10 Cells(i, 1).Value Item i Cells(i, 2).Value i * 10 Next i MsgBox 数据填充完成, vbInformation End Sub六、宏安全性设置由于宏可能包含恶意代码Excel 默认会阻止宏运行。6.1 信任中心设置文件→选项→信任中心→信任中心设置→宏设置┌─────────────────────────────────────┐ │ 宏设置 │ ├─────────────────────────────────────┤ │ ○ 禁用所有宏并且不通知 │ │ ○ 禁用所有宏并发出通知 ☜ 推荐 │ │ ○ 禁用无数字签署的所有宏 │ │ ○ 启用所有宏不推荐 │ └─────────────────────────────────────┘建议选择禁用所有宏并发出通知对可信文件手动启用。6.2 启用宏的方法当打开含宏的文件时Excel 会显示安全警告┌─────────────────────────────────────────┐ │ ⚠️ 安全警告 │ │ 已禁用宏。要启用内容请单击启用内容 │ │ │ │ [启用内容] │ └─────────────────────────────────────────┘点击启用内容即可运行宏。6.3 受信任位置将常用宏文件放在受信任位置可自动启用宏文件→选项→信任中心→信任中心设置→受信任位置七、本章小结知识点回顾知识点核心内容VBA 概念Excel 内置编程语言用于自动化操作开发工具显示选项卡、认识功能按钮宏录制录制操作 → 生成代码 → 运行宏VBE 环境工程资源管理器、属性窗口、代码窗口基本语法Sub…End Sub、MsgBox、Range安全性宏设置、启用内容、受信任位置下章预告下一章我们将深入学习VBA 基础语法包括变量声明与数据类型常量与数组运算符与表达式代码书写规范练习作业基础练习录制一个宏将选中的单元格设置为红色字体、蓝色背景进阶练习手动编写代码在 Sheet1 的 A1:F10 区域创建一个乘法表挑战练习编写代码弹出一个输入框接收用户输入的姓名然后在 A1 单元格显示欢迎XXX学习建议多录制宏然后查看生成的代码这是学习 VBA 最快的方式。试着修改录制的代码观察效果变化。本文是《Excel VBA 从入门到精通》系列第一篇文章持续更新中…

相关文章:

Excel VBA 入门到精通(一):宏录制与 VBE 环境详解

🎯 本章目标:从零开始,掌握 Excel VBA 开发环境的搭建,理解宏录制原理,并编写你的第一个 VBA 程序。一、什么是 VBA?VBA(Visual Basic for Applications)是微软开发的嵌入式编程语言…...

Python从入门到精通(第36章):多线程编程与线程安全

开头导语 写循环时,很多需求是重复的:拼接多个迭代器、取前N个、按相邻相同键分组……itertools 提供了这些常见迭代需求的函数式解决方案,更重要的是,所有函数都返回惰性迭代器——不占额外内存。本章围绕 itertools 模块展开,讲解 count/cycle/repeat、chain/islice/co…...

大模型学习-python学习Day5

一.函数函数是带名字的代码块,用于完成具体的任务,可重复使用,当需要在程序中多次执行同一项任务时,无须反复编写完成该任务的代码,只需要调用执行该任务的函数,让python运行其中的代码即可。python中的函数…...

从零配置ARM交叉编译环境:如何避免GLIBC版本陷阱(附工具链命名解析)

从零配置ARM交叉编译环境:如何避免GLIBC版本陷阱(附工具链命名解析) 刚接触嵌入式开发的工程师第一次尝试交叉编译时,往往会被各种工具链名称搞得晕头转向。更令人头疼的是,当你好不容易编译出可执行文件,却…...

从CubeMX到AC6:STM32H743的MPU与分散加载文件(.sct)配置避坑全记录(LWIP+FreeRTOS)

STM32H743网络协议栈实战:LWIPFreeRTOS在AC6编译器下的MPU与分散加载配置指南 1. 复杂存储架构下的开发挑战 STM32H7系列微控制器以其高性能和丰富的外设资源著称,但其复杂的存储架构也给开发者带来了不小的挑战。该系列芯片采用多总线矩阵和多种内存类型…...

如何批量创建SQL存储过程_使用脚本自动化部署流程

最稳妥的批量建存储过程方法是:SQL Server用sp_executesql逐个执行CREATE OR ALTER PROCEDURE;PostgreSQL用DO块pg_proc校验后EXECUTE;MySQL避免DELIMITER误替换,改用客户端分隔符控制。SQL Server 里用 sp_executesql 动态生成存…...

VisionPro图像掩膜进阶技巧:3步优化PMAlign工具匹配准确率(附真实案例)

VisionPro图像掩膜进阶技巧:3步优化PMAlign工具匹配准确率(附真实案例) 在精密视觉检测领域,PMAlign工具的准确率直接决定了整个系统的可靠性。上周在调试某半导体晶圆检测项目时,遇到一个典型问题:当检测图…...

SAMD微控制器安全Flash存储库设计与实践

1. 项目概述SAMD_SafeFlashStorage 是一款专为 SAMD21(如 Arduino Zero、MKR系列)和 SAMD51(如 Adafruit Metro M4、Arduino MKR VIDOR 4000)微控制器设计的安全型闪存数据存储库。它并非简单复刻,而是对原始 cmaglie/…...

鸿蒙 数据库构建查询条件:greaterThan

本文同步发表于微信公众号,微信搜索 程语新视界 即可关注,每个工作日都有文章更新 鸿蒙数据库中的 greaterThan 方法是用于构建查询条件(谓词)的一个核心操作符,它表示“大于”的比较关系,用于筛选出指定字…...

怎么为MongoDB事务调优:将读操作尽量移到事务外面执行

事务内读操作拖慢MongoDB性能,因其强制快照读导致锁范围扩大、快照开销上升、WiredTiger缓存压力增大;仅两类读必须留在事务内:依赖一致性的读和用于写冲突判断的读。为什么事务里做读操作会拖慢 MongoDB 性能MongoDB 事务本质是加锁 日志 …...

mysql数据库索引失效的常见原因_分析索引设计与使用误区

MySQL索引失效主因有三:WHERE中对字段用函数或表达式(如YEAR(create_time))、复合索引中范围查询后列无法命中、统计信息过期或数据倾斜致优化器误判;需改写为范围条件、定期ANALYZE TABLE并警惕隐式转换。WHERE 条件用了函数或表…...

【JAVA基础面经】线程安全的单例模式

文章目录单例模式(Singleton Pattern)一、饿汉模式二、懒汉模式解决懒汉式线程安全问题双重校验锁提高并发性能静态内部类(JDK 1.2)最佳方法:枚举方式(JDK 1.5)方法的对比单例模式(S…...

【CTFshow-pwn系列】03_栈溢出【pwn 062】详解:受限缓冲区下的极简 Shellcode 注入与利用实战

本文仅用于技术研究,禁止用于非法用途。 Author: 枷锁 在上一关(pwn 061)中,我们利用程序主动泄露的栈基址,通过 gets 函数毫无限制地在内存中挥洒 Payload。但 CTF 的竞技场绝不会永远如此慷慨。 来到 PWN 062&#x…...

ToF传感器自适应距离滤波框架ToFFilter深度解析

1. ToFFilter 库深度解析:面向 ToF 传感器的自适应距离滤波框架Time-of-Flight(ToF)传感器,如 ST 的 VL53L0X、VL53L1X 及其后续型号,在工业测距、机器人避障、手势识别、液位监测等嵌入式场景中已成主流。然而&#x…...

第三节课总结

一、计算机中的单位1、比特位(bit):一个比特位只能放一个二进制数据,要么0要么12.字节(byte):一个字节 8个比特位1024byte 1KB1024KB 1MB1024MB 1GB1024GB 1T1024TB 1PB3.每一种数据类型都可…...

用例模型,分析模型,领域模型和数据模型比较

用例模型、分析模型、领域模型、数据模型比较 在软件工程和系统分析中,用例模型、分析模型、领域模型、数据模型分别服务于不同阶段和不同目的。理解它们的区别与联系,有助于系统分析师构建完整、一致的解决方案。 一、各模型核心定位 模型 英文 核心目标 主要视角 主要受众…...

2026届毕业生推荐的六大降AI率方案推荐

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 要降低AIGC特征,得从语言习惯以及结构设计着手。别用常见的模板句式,…...

为什么Gartner刚下调3家明星厂商评级?AI原生数据库选型必须重看这7项硬指标,否则Q3上线即重构

第一章:Gartner评级下调背后的AI原生数据库范式转移 2026奇点智能技术大会(https://ml-summit.org) Gartner近期将多家传统关系型数据库厂商在“云数据库管理系统魔力象限”中的位置下调,其公开报告明确指出:“评估标准已从‘事务吞吐与SQL…...

Zabbix简介及部署

目录 一、Zabbix 核心介绍 1. 核心特性 2.核心组件(架构) 二、Zabbix 部署 步骤 1:系统初始化 步骤 2:服务器上部署zabbix-server 步骤 3:系统安装中文语言包 步骤 4:Web 界面初始化 步骤 5&#…...

AI驱动的软件文档闭环:从代码提交到API文档/PRD/测试用例自动生成(实测准确率92.6%,已交付37个生产系统)

第一章:AI原生软件研发文档自动化生成方案 2026奇点智能技术大会(https://ml-summit.org) AI原生软件研发正面临文档滞后、语义割裂与维护成本激增的三重挑战。传统文档生成依赖人工补全或静态模板,难以响应代码逻辑的实时演进;而AI驱动的文…...

【AI原生代码审查实战指南】:2026奇点大会首发的7大审查范式与3类高危漏洞自动拦截模型

第一章:2026奇点智能技术大会:AI原生代码审查 2026奇点智能技术大会(https://ml-summit.org) 在2026奇点智能技术大会上,“AI原生代码审查”不再作为辅助工具存在,而是深度嵌入软件开发生命周期的每个环节——从提交前的本地预检…...

N20 设备驱动程序

一、驱动程序驱动 内核的一部分,操作系统把硬件 “关起来”,只让驱动碰,应用程序只能通过系统调用访问。因为硬件不能直接给应用程序用,必须由操作系统统一管理,驱动就是操作系统跟硬件之间的翻译官。为应用层提供设备的操作方法…...

这个效率技巧,能找回你复制过的内容

很多人不知道,复制内容其实可以看历史记录。 也就是说,你复制过的内容,不一定只能保留最后一条。 Windows:系统自带 如果你用的是 Windows 10 / 11,系统已经内置了这个功能。 直接按:Win V 第一次使用…...

别再死磕Softmax了!清华黄高团队新作Agent Attention,让Transformer在高分辨率图像上也能飞起来

Agent Attention:突破Transformer高分辨率瓶颈的下一代注意力机制 当你在Stable Diffusion中生成一张4K图像时,是否遇到过显存爆满的尴尬?当用DeiT处理医学影像时,是否因计算资源不足而被迫降低分辨率?这些痛点背后&am…...

YOLOv8 智能交通违章检测 - 车牌识别与黑名单比对详解

YOLOv8 智能交通违章检测 - 车牌识别与黑名单比对详解 在交通违章检测系统中,车牌识别 (License Plate Recognition, LPR) 是锁定违法主体的关键,而黑名单比对则是实现自动预警和布控的核心业务逻辑。 本方案采用 YOLOv8 (车牌检测) + CRNN/LPRNet (字符识别) + 内存/Redis…...

文本三剑客命令手册

文本三剑客命令手册(grep、sed、awk) 一、grep — 文本搜索利器 基本语法 grep [选项] 模式 文件名常用选项 选项 说明 -i 忽略大小写 -v 反向匹配(显示不匹配的行) -n 显示匹配行的行号 -c 统计匹配行数 -l 只显示包含匹配的文件名 -L 只显示不包含匹配的文件名 -r / -R 递…...

使用ffmpeg本地发布rtmp/rtsp直播流

1 FFmpeg的选择与下载 选择合适的版本 首先,访问FFmpeg官方下载页面(https://ffmpeg.org/download.html),在这里可以找到最新的稳定版或 nightly 构建版本。对于大多数常规用途,推荐下载预编译的Windows静态版本&a…...

AI民主化:让每个人都能开发AI应用,是理想还是泡沫?

在人工智能(AI)技术飞速发展的今天,“AI民主化”已成为热门议题——它承诺让非专业开发者也能轻松创建AI应用,打破技术壁垒。然而,作为软件测试从业者,我们不禁要问:这究竟是推动创新的理想愿景…...

4、 说说webpack proxy工作原理?为什么能解决跨域?

目录 🌐 什么是 Webpack Proxy? 🧠 核心原理 为什么会有跨域问题? Proxy 如何解决跨域? 🔧 底层实现 请求转发流程 关键配置解析 changeOrigin: true 的作用 pathRewrite 的作用 🆚 与…...

ArcGIS JS 基础教程(1):地图初始化(含AMD/ESM两种引入方式)

ArcGIS JS 系列基础教程(100个项目常用热门功能) 一、地图基础操作 1. ArcGIS JS 基础教程(1):地图初始化(含AMD/ESM两种引入方式) 功能介绍:ArcGIS JS 开发的基础,实…...