一小时搞定简单VBA编程 Excel宏编程快速上手

一小时搞定简单VBA编程 Excel宏编程快速上手Excel宏编程可以快速完成批量表格操作:复制粘贴、数据过滤等,宏代码基于VB语言实现,有基础的编程经验就能快速阅读。下面是我的学习笔记。1.ExcelVBA编辑界面(进入路径:sheet名称–>鼠标右键菜单–>查看代码)2.输入代码方法:在VBE编辑器的代码模块中输入VBA代码,通常有以下几种方法:■手工键盘输入;■使用宏录制器,即选择菜单“工具—…

大家好,又见面了,我是你们的朋友全栈君。

Excel宏编程可以快速完成批量表格操作:复制粘贴、数据过滤等,宏代码基于VB语言实现,有基础的编程经验就能快速阅读。下面是我的学习笔记。

1. Excel VBA编辑界面

(进入路径: sheet名称 –> 鼠标右键菜单 –> 查看代码)

2. 输入代码方法:

在VBE编辑器的代码模块中输入VBA代码,通常有以下几种方法:

■ 手工键盘输入;

■ 使用宏录制器,即选择菜单“工具——宏——录制新宏”命令,将所进行的操作自动录制成宏代码;

■ 复制/粘贴代码,即将现有的代码复制后,粘贴到相应的代码模块中;

■ 导入代码模块:文件–>导入文件 **不用的模块可以:文件–>移出模块

3. VB代码阅读扫盲
(1) 模块声明:

Sub sName() … End Sub
Sub xxxxx()
XXXXXXXXX
End Sub

(2) 变量声明:

Dim sPara As sType
Dim para1, para2, para3
Dim para4 As workbook, para5 As String
Dim G As Long

(3) 选择结构:

With … End With
If condition Then … End If

举个例子:遍历每个Sheet把表粘贴成一个大表的语句,使用For Next With End With语句

With Workbooks(1).ActiveSheet
For G = 1 To Sheets.Count
Wb.Sheets(G).UsedRange.Copy .Cells(.Range(“B65536”).End(xlUp).Row + 1, 1)
Next
WbN = WbN & Chr(13) & Wb.Name
Wb.Close False
End With

(4) 循环结构

Do While condition … Loop
For i = 0 to 100 … Next

(5) 输出Log:

MsgBox sString
案例解析:解析拷贝路径下所有Excel到一个工作表下的示例:


Sub 合并当前目录下所有工作簿的全部工作表() #模块名称
Dim MyPath, MyName, AWbName #变量声明
Dim Wb As workbook, WbN As String
Dim G As Long
Dim Num As Long
Dim BOX As String
Application.ScreenUpdating = False #停止屏幕刷新
MyPath = ActiveWorkbook.Path #获取当前工作文件路径
MyName = Dir(MyPath & “” & “*.xls”) #获取当前文件名(截取字符串)
AWbName = ActiveWorkbook.Name #获取当前BookName
Num = 0 #准备进入循环处理
Do While MyName <> “” #第一个循环体:遍历所有文件 终止条件是 文件名为空
If MyName <> AWbName Then #条件:文件名当前激活文件不同
Set Wb = Workbooks.Open(MyPath & “” & MyName) # 设置工作表的名称(当前Sheet Name)
Num = Num + 1 #计数用于输出
With Workbooks(1).ActiveSheet
.Cells(.Range(“B65536”).End(xlUp).Row + 2, 1) = Left(MyName, Len(MyName) – 4)
#赋值语句:激活Sheet的A列最后一个单元格赋值为MyName去掉‘.xls’的部分
#Left 截取字符串 去掉了’.xls’
#workbooks(n) 为取工作簿 的写法
#A65535(一个极大数)单元格向上,最后一个非空的单元格的行号
For G = 1 To Sheets.Count #嵌套循环体:遍历文件的所有Sheets
Wb.Sheets(G).UsedRange.Copy .Cells(.Range(“B65536”).End(xlUp).Row + 1, 1)
#赋值所有内容到以结束内容空一行开始的表格中
Next #且套循环体结束
WbN = WbN & Chr(13) & Wb.Name # & 为合并字符串的符号
Wb.Close False #对于文件操作结束,关闭Excel文件
End With #退出第二个判断
End If #退出第一个判断
MyName = Dir #怎么拿到第二个bookName
Loop #循环体结束
Range(“B1”).Select #选中B1
Application.ScreenUpdating = True #允许Excel屏幕刷新
MsgBox “共合并了” & Num & “个工作薄下的全部工作表。如下:” & Chr(13) & WbN, vbInformation, “提示”
End Sub


常用模块:

1. 把一个workBook的一块表格拷贝到另一个WorkBook中的一般化方法:

上面的代码中是一种简单的实现:拷贝所有内容到空行区域

需要将拷贝的内容和粘贴的位置控制更加精准控制:

拷贝指定位置到指定位置:

Workbooks(“工作簿1.xls”).Sheet1.Range(“A1:C50”).Copy ThisWorkbook.Sheet2.Range(“A1”)

2. 找到粘贴位置:

b=sheet2.[BI].end(xlToLeft).row+1 获取最后一次编辑的各自的列号!

.Range(“B65536”).End(xlUp).Row + 2 最后一次编辑的格子的行号
A1 直接编辑

.Cells(nRowNo, nColNo)

实战案例分析:一个将多个相同格式表格合并生成横表的例子:

Sub 合并当前目录下所有工作簿的全部工作表()

Dim MyPath, MyName, AWbName
Dim Wb As Workbook, WbN As String
Dim G As Long
Dim Num As Long
Dim BOX As String
Dim HasTitil As Boolean
Dim LastRange As String
Dim CurRowNo As Long

Application.ScreenUpdating = False
MyPath = ActiveWorkbook.Path
MyName = Dir(MyPath & “” & “*.xls”)
AWbName = ActiveWorkbook.Name
Num = 0
HasTitil = False

With Workbooks(1).ActiveSheet
.Cells(1, 2) = “Cor.Name
Do While MyName <> “”
If MyName <> AWbName Then
Set Wb = Workbooks.Open(MyPath & “” & MyName)
Num = Num + 1
.Cells(1, Num + 2) = Left(MyName, Len(MyName) – 4)

If HasTitil <> True Then

Wb.Sheets(1).Range(“A4:B43”).Copy .Cells(2, 1)
Wb.Sheets(1).Range(“E4:F43”).Copy .Cells(.Range(“A65536”).End(xlUp).Row + 1, 1)
Wb.Sheets(2).Range(“A5:B73”).Copy .Cells(.Range(“A65536”).End(xlUp).Row + 1, 1)
Wb.Sheets(2).Range(“E5:F73”).Copy .Cells(.Range(“A65536”).End(xlUp).Row + 1, 1)
Wb.Sheets(3).Range(“A4:B32”).Copy .Cells(.Range(“A65536”).End(xlUp).Row + 1, 1)
Wb.Sheets(3).Range(“E4:F32”).Copy .Cells(.Range(“A65536”).End(xlUp).Row + 1, 1)
Wb.Sheets(4).Range(“A5:B100”).Copy .Cells(.Range(“A65536”).End(xlUp).Row + 1, 1)

HasTitil = True
End If

CurRowNo = 2
Wb.Sheets(1).Range(“D4:D43”).Copy .Cells(CurRowNo, Num + 2)
CurRowNo = CurRowNo + 40
Wb.Sheets(1).Range(“H4:H43”).Copy .Cells(CurRowNo, Num + 2)
CurRowNo = CurRowNo + 40
Wb.Sheets(2).Range(“D5:D73”).Copy .Cells(CurRowNo, Num + 2)
CurRowNo = CurRowNo + 69
Wb.Sheets(2).Range(“H5:H73”).Copy .Cells(CurRowNo, Num + 2)
CurRowNo = CurRowNo + 69
Wb.Sheets(3).Range(“D4:D32”).Copy .Cells(CurRowNo, Num + 2)
CurRowNo = CurRowNo + 29
Wb.Sheets(3).Range(“H4:H32”).Copy .Cells(CurRowNo, Num + 2)
CurRowNo = CurRowNo + 29
Wb.Sheets(4).Range(“D5:D100”).Copy .Cells(CurRowNo, Num + 2)

Wb.Close False
End If
MyName = Dir
Loop

End With

Range(“B1”).Select
Application.ScreenUpdating = True
End Sub

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/134316.html原文链接:https://javaforall.net

(0)
上一篇 2022年6月6日 下午11:46
下一篇 2022年6月6日 下午11:46


相关推荐

  • ps基础快捷键_ps确定的快捷键

    ps基础快捷键_ps确定的快捷键ps快捷键常用表,ps快捷键大全!天下武功,唯快不破!看完这篇PS快捷键使用指南,帮你掌握最常用的32个Photoshop快捷键!注:左上为Mac快捷键,右上为PC快捷键1、Command+T:自由变形该快捷键,主要对图层进行旋转、缩放等变形调整,同时可以拖动修改图层在画面中的位置,是极为常用的功能键。2、Command+J:复制图层对图层的复制,一般的操作是通过图层菜单栏选择,或者…

    2026年4月18日
    4
  • python激活_在线激活「建议收藏」

    (python激活)2021最新分享一个能用的的激活码出来,希望能帮到需要激活的朋友。目前这个是能用的,但是用的人多了之后也会失效,会不定时更新的,大家持续关注此网站~IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.html…

    2022年3月30日
    193
  • spdlog用法

    spdlog用法转自:https://blog.csdn.net/haojie_superstar/article/details/89383433?utm_medium=distribute.pc_relevant.none-task-blog-BlogCommendFromBaidu-19.control&dist_request_id=1328730.643.16167433128441371&depth_1-utm_source=distribute.pc_relevant.none-task-bl

    2022年6月23日
    27
  • c++ uint32_t_int32和uint32

    c++ uint32_t_int32和uint32文章目录使用int64_t形式代替基本类型使用原因stdint.h源码int32_t和uint32_t的区别size_t在不同机器中定义不同:参考文档使用int64_t形式代替基本类型我们都知道,C语言的基本类型就char,short,int等。但是我们在看其他源码时经常碰到int32_t,int8_t这种形式的定义,他们是什么呢。其实他们就是基本类型的typedef重定义。也就是不同平台下,使用以下名称可以保证固定长度。1字节int8_t——char2字节int1

    2026年2月2日
    5
  • 数学建模之方差分析模型_数学建模层次分析法

    数学建模之方差分析模型_数学建模层次分析法《数学建模算法与应用》学习小结(11-20章)方差分析(AnalysisofVariance,ANOVA)应用场景单因素方差分析双因素方差分析方差分析(AnalysisofVariance,ANOVA)——用数理统计分析试验结果,鉴别各因素对结果影响程度的方法。人们关心的试验结果称为指标,试验中需要考察、可以控制的条件称为因素或因子,因素所处的状态称为水平应用场景为了使生产过…

    2022年10月15日
    5
  • Kotlin入门(20)几种常见的对话框

    Kotlin入门(20)几种常见的对话框提醒对话框手机上的App极大地方便了人们的生活,很多业务只需用户拇指一点即可轻松办理,然而这也带来了一定的风险,因为有时候用户并非真的想这么做,只是不小心点了一下而已,如果App不做任何提示的话,继续吭哧吭哧兀自办完业务,比如转错钱了、误删资料了,往往令用户追悔莫及。所以对于部分关键业务,App为了避免用户的误操作,很有必要弹出消息对话框,提醒用户是否真的要进行此项操作。这个提醒对话框便是Ap…

    2022年6月22日
    102

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号