首页
/
每日頭條
/
科技
/
vba代碼詳細講解
vba代碼詳細講解
更新时间:2025-02-23 19:58:05

vba代碼詳細講解?Excel宏編程可以快速完成批量表格操作:複制粘貼、數據過濾等,宏代碼基于VB語言實現,有基礎的編程經驗就能快速閱讀 ,現在小編就來說說關于vba代碼詳細講解?下面内容希望能幫助到你,我們來一起看看吧!

vba代碼詳細講解(你也可以快速掌握簡單VBA編程)1

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

,
Comments
Welcome to tft每日頭條 comments! Please keep conversations courteous and on-topic. To fosterproductive and respectful conversations, you may see comments from our Community Managers.
Sign up to post
Sort by
Show More Comments
推荐阅读
蘋果手機最近突然死機了怎麼辦
蘋果手機最近突然死機了怎麼辦
很多人都喜歡使用iphone手機,它比其他的手機更快,也更不容易卡。但是,我發現一個問題,就是手機都是開始用的時候流暢,而用久了就會出現死機等現象。在我們接電話前,或者玩遊戲時等等一些情況,手機就會突然的死機。而很多人這時候會覺得特别煩躁,...
2025-02-23
在評論區留下你的qq号
在評論區留下你的qq号
編者按:本文來自Phala可信網絡(ID:phala_network),作者:Marvin,Odaily星球日報經授權轉載。本文中的所有查詢到的敏感結果已經打碼,保護當事人隐私本人作者已将所有查詢到的信息删除清空本文寫作較為草率,如有不準确...
2025-02-23
蘋果最佳手機排行榜
蘋果最佳手機排行榜
那些年iphone還沒改變世界,各大手機品牌百花齊放。下面就讓小編來給大家盤點下,當年那些各大手機品牌所謂的機皇,炫酷感甩爆iphone八條街!摩托羅拉RAZR2V8摩托羅拉這款手機的外型設計已經非常成熟,極緻薄的厚度和接近180度的大翻蓋...
2025-02-23
雪佛蘭科魯澤USB連接手機怎樣發照片
雪佛蘭科魯澤USB連接手機怎樣發照片
雪佛蘭科魯澤USB連接手機怎樣發照片?關于雪佛蘭科魯澤USB鍊接手機怎樣發照片,可以先将雪佛蘭科魯澤RS屏幕與手機聯接,鍊接方法如下:打開你的雪佛蘭在打開你的手機藍牙搜索到以後配對一下,首次配對輸入五個八,配對成功就行了,我來為大家講解一下...
2025-02-23
怎麼做好一份紅頭文件
怎麼做好一份紅頭文件
一近一個月備戰中經,把班後業務時間全部貢獻給了複習。随着考試的圓滿結束,公衆号的更新将恢複往日的頻次:一周至少三次。中經經濟基礎,考試題目并不難,但涉及的科目及知識點相當多,前期的複習建議是看書、背誦、做題穿插,循序漸進;考前要預留至少40...
2025-02-23
Copyright 2023-2025 - www.tftnews.com All Rights Reserved