抖音资讯

douyinzx

excel宏编程用什么语言(excel宏代码编写教程)

iseeyu2年前 (2024-05-09)抖音资讯123

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

1. Excel VBA编辑界面

(Alt+F11)

 

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://0291.com.cn/post/42154.html

相关文章

凭抖音号怎么查个人资料信息(抖音个人账号网址查询方法)

凭抖音号怎么查个人资料信息(抖音个人账号网址查询方法)

个人档案怎么查,不少玩家都不清楚,那么在什么位置可以查到自己的信息呢,下面为大家介绍闽政通个人档案查询方法。 个人档案查询方法 大家不同地区需要下载相对应的APP即可以查看自己信息啦 操作步骤:打开闽政通app-我的-个人档案,就可以查看了。 个人档案里面包含了从个人出生开始到缴...

抖音同城推广这个到底怎么样?

抖音同城推广这个到底怎么样?

一、号是什么?它吗?同城号,顾名思义就是在同一座城市发布的视频,在发布视频之前,通过选择“你在哪里”的选项,发布之后,视频就会出现在首页左侧「城市」的位置,和你一座城市的人将会有更大的几率刷到你的视频。说起同城号,大家肯定会先想到一些探店的账号,这确实也是现在同城账号当中最...

快手广告打开新线市场之门:不是下沉,而是增长;不是小众,而是大众

快手广告打开新线市场之门:不是下沉,而是增长;不是小众,而是大众

快手广告打开新线市场之门:不是下沉,而是增长;不是小众,而是大众 近两年,随着一线市场渐趋成熟,三四线城市吸引力不断加强。新线城市以其可期的增长潜力,日益成为品牌关注的增量市场。相应地,新线市场人群也越来越受关注:什么是新线青年的“社交货币”?如何找到与新线青年的沟通密码,才能保持品牌的持续增长?...

承德用最冷静的态度走入快手直播推广课

承德用最冷静的态度走入快手直播推广课

什么是快手直播推广?如何做承德商业直播?直播的未来是什么?品牌关注直播的意义是什么?那里有直播。如何为我使用它?关于直播,大家有不同的看法,但目前还没有定论 这样的背景,产生的巨大的引擎营销中心的颤音广告生活大师班修炼学校”,邀请公司,m cn,人才,蓝色V代理方”颤音住先锋”,从不同的维度...

速看!2023抖音运营干货!从入门到精通(内容创作)

速看!2023抖音运营干货!从入门到精通(内容创作)

如果有人问,未来的商业机会可能会隐于何处?相信其中的一个答案,会是“在兴趣之中”。在抖音平台中很多的抖音用户都是新用户对于这些新抖音用户来说可能还不知道如何去运营账号那么新手抖音运营从哪开始学?下面就和大家分享抖音运营教程PART1创作工具抖音从入门到精通PART1创作工具...

抖音粉丝和关注有什么区别(关于抖音关注的意思解释)

抖音粉丝和关注有什么区别(关于抖音关注的意思解释)

关注和粉丝的区别,关注的局限在于其他人可能无法第一时间看到用户的内容。粉丝,粉丝的限制是用户只能通过搜索粉丝才能看到其他人的内容。   一、概念称谓 不同的注意力是指通过自己对他人的关注而增加的注意力。有单向注意、多重注意或相互注意,属于动词范...

现在,非常期待与您的又一次邂逅

我们努力让每一部企业宣传片和抖音短视频成为商业大片