几句小白都会的 VBA 代码,让工作效率提升百倍!(附常用代码)
moboyou 2025-06-10 00:01 19 浏览
接昨天的自定义函数,今天就教大家几个常用的 VBA 代码!
相信不少小伙伴一听到 VBA,立马纷纷后退,将它视作洪水猛兽。
其实,VBA 代码并不可怕,只是因为我们接触得不多不了解,又总听到厉害的人说起它,所以才觉得它又神秘又可怕。
而今天,小 E 就要来揭开 VBA 代码的神秘面纱,并且介绍几个常用的简单代码,能够让大家非常方便地运用到工作中去,大大提升工作效率。
那首先就跟着小 E 了解下相关操作的基础常识吧~
- 1 -
认识 VBA 编辑器
大家都知道 Excel 中数据存放在单元格里,可你们知道 VBA 代码要存放在什么地方?
答案就是 VBA 编辑器,如下图所示:
那要如何打开 VBA 编辑器呢?下面教大家三种方法。
方法一
通过选项卡打开
单击【开发工具】选项卡,找到【Visual Basic】命令,单击即可进入 VBA 编辑器,如下图所示:
如果菜单栏里没有【开发工具】选项卡,按照这个步骤把它调出来——点击【文件】-【选项】,然后点击【自定义功能区】,在「主选项卡」中勾选「开发工具」,点击【确定】即可。
方法二
通过右键工作表标签查看代码打开
右键单击任意一个工作表标签,在弹出的菜单中单击【查看代码】,即可进入 VBA 编辑器,如下图所示:
方法三
通过快捷键打开
在任意一个工作表中,使用快捷键【Alt+F11】,即可进入 VBA 编辑器,不过有些笔记本可能需要再同时按下【Fn】键才可以。
- 2 -
如何运行 VBA 代码
我们大多数的 VBA 代码都是存放在 VBA 编辑器的模块中,那模块又是如何添加的呢?
在左侧的工程资源管理器中,右键单击【Thisworkbook】或者上面的任意一个工作表的标签均可弹出一个菜单,在菜单中单击【插入】,在弹出的下一级菜单中选择【模块】,单击即可插入 1 个模块,如下图所示:
我们知道存放 VBA 代码的地方了,那如何运行 VBA 代码呢?
单击【开发工具】选项卡,找到【宏】命令,单击即可,如下图所示:
在弹出的【宏】对话框中可以看到我们已经写好的 VBA 宏的名称,单击选中要执行的宏名称,单击【执行】即可执行 VBA 代码了,如下图所示:
- 3 -
常用的 VBA 代码
相信现在你已经掌握了 VBA 代码相关的基础操作,那接下来小 E 就给大家贴上几个常用的简单 VBA 代码~
只有短短几行,但却能帮我们节约不少时间!
批量保护/取消保护工作表
有时候为了防止别人误操作,需要给工作表加保护密码,但是工作表数量太多,一个个地设置保护也是个体力活儿,这个时候如果用了下面的 VBA 代码就方便快捷多了!
Sub 保护工作表() Dim i As Long For i = 1 To Sheets.Count Sheets(i).Protect "123" Next End Sub
给大家大致解释下代码——
第一行是定义宏的名称,比如这个宏的名称叫做「保护工作表」,最后一行是结束,这两行是固定用法。 第二行 Dim 是在定义变量的类型,这里是定义变量 i 为长整数型。 第三行和第五行是 For Next 循环的用法,Sheets.Count 是指工作表的个数,For i = 1 To Sheets.Count 表示从第一个表循环到最后一个表,都执行 For 与 Next 中间的代码。 第四行是主要的功能代码,Sheets(i).Protect 通过变量 i 的变化,对逐个工作表进行保护,后面的字符串 123 是密码,密码可以根据需要自己修改。
那取消保护工作表的代码又该如何写呢?
其实,宏名称改一下,再修改第四行的代码就可以了!修改后的代码如下:
Sub 取消保护工作表() Dim i As Long For i = 1 To Sheets.Count Sheets(i).Unprotect "123" Next End Sub
批量重命名工作表
有时我们建立了很多工作表,工作表名称是 Sheet1、Sheet2 这种,这让我们查看数据时很难分清,需要重新命名工作表。一个一个工作表来,估计又要忙活一会儿了!
比如我们要把 Sheet2 工作表及后面所有的工作表名称都修改为每个工作表中 C2 单元格的值,也就是将工作表名称修改为部门名称,方便查看每个部门的情况。
我们的 VBA 代码又派上用场了:
Sub 修改工作表名称() Dim i As Long For i = 2 To Sheets.Count Sheets(i).Name = Sheets(i).Range("C2") Next End Sub
给大家大致解释下代码——
第一行、第二行、第五行及第六行,与前面代码功能一致,在此不再赘述。 第三行仍为循环,只是改为从第二个工作表开始循环,所以使用了 For i = 2 开始,直到最后一个工作表。 第四行是关键的修改工作表名称的代码,Sheets(i).Name 代表这个工作表的名称,等于这个工作表中 C2 单元格的值。
- 4 -
小心这些「坑」
保存时注意文件类型
如果你的文件扩展名为「.xlsx」,添加代码后,文件在保存时会有下图所示的提示:
此时要点击【否】,保存文件格式的时候选择「Excel 启用宏的工作簿(*.xlsm)」,然后单击【保存】即可。
如果选择了【是】,文件关闭后再打开时将丢失 VBA 代码。
打开有宏代码的工作簿
如下图所示,当打开带有宏代码的工作簿时,会有安全警告(宏已被禁用),这时需要单击【启用内容】来启用宏,才可以运行相关的宏代码。
如果不启用宏,代码将不能运行,点击运行相关代码时会有如下图所示的提示:
好了,VBA 从入门到几个常用的简单代码都教给你了,你都学会了吗?
当然小 E 知道,这些只是九牛一毛,但如果你有兴趣的话,可以在掌握基础之后进行探索,或许会发现一座不一样的新世界!
而后面小 E 也会陆续为大家带来运用 VBA 解决工作问题的文章,想看的小伙伴就在文末点个「赞」吧!
- 上一篇:excel运行宏的方式集合
- 下一篇:数控龙门铣床宏程序集锦
相关推荐
- Jsp+Ssh+Mysql实现的论坛系统源码附带视频指导运行教程
-
今天给大家来演示一下一款有spring+struts2+hibernate+mysql实现的Javaweb论坛系统源码,系统项目源代码在【猿来入此】获取!https://www.yuanlrc.co...
- 仓库管理系统Java入库出库jsp源代码Mysql
-
本项目为前几天收费帮学妹做的一个项目,JavaEEJSP项目,在工作环境中基本使用不到,但是很多学校把这个当作编程入门的项目来做,故分享出本项目供初学者参考。一、项目介绍仓库管理系统项目有1个权...
- SSM叮当书城java图书商城jsp源代码mysql
-
本项目为前几天收费帮学妹做的一个项目,JavaEEJSP项目,在工作环境中基本使用不到,但是很多学校把这个当作编程入门的项目来做,故分享出本项目供初学者参考。一、项目介绍SSM叮当书城系统有1权限...
- 教务管理系统,jsp+java学生教师课程web源代码mysql
-
本项目为前几天收费帮学妹做的一个项目,JavaEEJSP项目,在工作环境中基本使用不到,但是很多学校把这个当作编程入门的项目来做,故分享出本项目供初学者参考。一、项目描述ssm考勤管理系统运行环境...
- 医药信息管理系统servlet jsp药品医院进销存源代码mysql
-
本项目为前几天收费帮学妹做的一个项目,JavaEEJSP项目,在工作环境中基本使用不到,但是很多学校把这个当做编程入门的项目来做,故分享出本项目供初学者参考。一、项目描述医药信息管理系统servl...
- 音乐盒Java在线音乐jsp源代码Mysql
-
本项目为前几天收费帮学妹做的一个项目,JavaEEJSP项目,在工作环境中基本使用不到,但是很多学校把这个当作编程入门的项目来做,故分享出本项目供初学者参考。一、项目介绍音乐盒项目有1个权限:用...
- 物流管理系统Java货运快递jsp源代码Mysql
-
本项目为前几天收费帮学妹做的一个项目,JavaEEJSP项目,在工作环境中基本使用不到,但是很多学校把这个当作编程入门的项目来做,故分享出本项目供初学者参考。一、项目介绍物流管理系统系统有1权限...
- SSM仓库管理系统Java出库入库jsp源代码Mysql
-
本项目为前几天收费帮学妹做的一个项目,JavaEEJSP项目,在工作环境中基本使用不到,但是很多学校把这个当作编程入门的项目来做,故分享出本项目供初学者参考。一、项目介绍SSM仓库管理系统系统有...
- 基于SSM的bbs聊天论坛java jsp贴吧留言板聊天室mysql源代码
-
本项目为前几天收费帮学妹做的一个项目,JavaEEJSP项目,在工作环境中基本使用不到,但是很多学校把这个当作编程入门的项目来做,故分享出本项目供初学者参考。一、项目描述基于SSM的bbs聊天论坛...
- 一文了解MySQL Binlog(一文了解多地楼市新政)
-
MySQL的Binlog日志是一种二进制格式的日志,Binlog记录所有的DDL和DML语句(除了数据查询语句SELECT、SHOW等),以Event的形式记录,同时记录语句执行时...
- Jsp Servlet Mysql实现的Java Web在线商城项目源码附运行视频
-
今天给大家演示一款由jspservletMySQL实现的在线商城系统,本系统实现了管理员管理用户、商品(商品分类)、订单、留言、新闻等功能,系统项目源代码在【猿来入此】获取!前台会员注册登录,查看...
- 蓝易云 - Ubuntu 18.04系统编译安装MySQL 5.7教程。
-
在Ubuntu18.04系统上编译安装MySQL5.7的详细教程下面是一份关于如何在Ubuntu18.04系统上编译并安装MySQL5.7的详细教程。通过这个过程,您可以手动编译并安装MySQ...
- Jsp+Servlet+Mysql在线图书商城源码附论文开题报告及指导视频
-
今天给大家演示的是一款由jsp+servlet+mysql实现的在线图书商城系统,主要分为前台后后台管理员功能,前台用户可以浏览查看各类图书信息,可自定义搜索,注册登录后可以将书添加到购物车,购物车中...
- 基于swing的科研管理系统java jsp项目信息统计mysql源代码
-
本项目为前几天收费帮学妹做的一个项目,JavaEEJSP项目,在工作环境中基本使用不到,但是很多学校把这个当作编程入门的项目来做,故分享出本项目供初学者参考。一、项目描述基于swing的科研管理系...
- 基于Fis3和Idtc的头条前端开发套件安装及使用向导
-
基于Fis3和Idtc的头条前端开发套件安装及使用向导以下简称套件背景Fis3是一款百度开发的前端构建工具(http://fis.baidu.com/),头条前端之前的开发模式基于Fis2,大体上基本...
- 一周热门
- 最近发表
- 标签列表
-
- 外键约束 oracle (36)
- oracle的row number (32)
- 唯一索引 oracle (34)
- oracle in 表变量 (28)
- oracle导出dmp导出 (28)
- oracle两个表 (20)
- oracle 数据库 字符集 (20)
- oracle安装补丁 (19)
- matlab化简多项式 (20)
- 多线程的创建方式 (29)
- 多线程 python (30)
- java多线程并发处理 (32)
- 宏程序代码一览表 (35)
- c++需要学多久 (25)
- css class选择器用法 (25)
- css样式引入 (30)
- css教程文字移动 (33)
- php简单源码 (36)
- php个人中心源码 (25)
- php小说爬取源码 (23)
- 云电脑app源码 (22)
- html画折线图 (24)
- docker好玩的应用 (28)
- linux有没有pe工具 (34)
- mysql数据库源码 (21)