用VBA合并Excel工作簿._第1頁(yè)
用VBA合并Excel工作簿._第2頁(yè)
用VBA合并Excel工作簿._第3頁(yè)
用VBA合并Excel工作簿._第4頁(yè)
用VBA合并Excel工作簿._第5頁(yè)
免費(fèi)預(yù)覽已結(jié)束,剩余1頁(yè)可下載查看

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、有許多實(shí)現(xiàn)Excel工作簿合并的方法,在將多個(gè)工作簿中的數(shù)據(jù)合并到一個(gè)工 作簿中介紹過(guò)例如,需要將多個(gè)Excel工作簿中的工作表合并到一個(gè)工作簿。這里假設(shè)需要合 并的工作簿在“ D示例Sub Comb in eWorkbooks(Dim strFileName As Stri ngDim wb As WorkbookDim ws As Object包含工作簿的文件夾,可根據(jù)實(shí)際修改示例數(shù)據(jù)記錄Applicati on .Scree nUpdat ing = FalseSet wb = Workbooks.Add(xlWorksheetstrFileName = Dir(strFileDir &

2、 *.xls*Do While strFileName vbNullStri ngDim wbOrig As WorkbookSet wbOrig = Workbooks.Ope n( File name:=strFileDir & strFileName,Read Only :=TruestrFileName = Left(Left(strFileName, Le n(strFileName - 4, 29For Each ws In wbOrig.Sheetsws.Copy After:=wb.Sheets(wb.Sheets.Co untIf wbOrig.Sheets.Count 1

3、Thenwb.Sheets(wb.Sheets.Co un t.Name = strFileName & ws.ln dexElsewb.Sheets(wb.Sheets.Co un t.Name = strFileNameEnd IfNextwbOrig.Close SaveCha nges:=FalsestrFileName = DirLoopApplicatio n.DisplayAlerts = Falsewb.Sheets(1.DeleteApplicatio n.DisplayAlerts = TrueApplicati on .Scree nUpdat ing = TrueSet

4、 wb = Nothi ngEnd Sub示例文檔下載:下面是合并多個(gè)Excel工作簿的另一種情形,也是Excel VBA實(shí)戰(zhàn)技巧精粹中 技巧91:匯總有四個(gè)工作簿,分別為:匯總工作簿.xls、一月.xls、二月.xls、三月.xls,其中一 月.xls、二月.xls在匯總工作簿.xls中打開(kāi)VBE,并輸入下列代碼:Sub Con solidateWorkbook(Dim Ran geArray( As Stri ngDim bk As WorkbookDim sht As WorksheetDim WbCou nt As In tegerWbCou nt = Workbooks.Cou nt

5、ReDim Ran geArray(1 To WbCou nt - 1For Each bk In Workbooks在所有工作簿中循環(huán)If Not bk Is ThisWorkbook The n非代碼所在工作簿Set sht = bk.Worksheets(1引用工作簿的第一個(gè)工作表i = i + 1Ran geArray(i = & bk.Name & & sht.Name & ! & _sht.Range(A1.CurrentRegion.Address(ReferenceStyle:=xlR1C1 End IfNextWorksheets(1.Ra nge(A1.Co nsolida

6、te _Ran geArray, xlSum, True, TrueEnd Sub運(yùn)行上述代碼前,必須打開(kāi)所有的工作簿。運(yùn)行代碼后,將自動(dòng)匯總所有工作表 中的值并將相應(yīng)示例文檔下載:下面是匯總多個(gè)工作簿的又一種情形,也是一名網(wǎng)友提出的問(wèn)題:在同一文件夾 中有多個(gè)工作簿,其中Sub Un io nWorksheets(Applicati on .Scree nUpdat ing = FalseDim lj As Stri ngDim dir name As Stri ngDim nm As Stri nglj = ActiveWorkbook.Pathnm = ActiveWorkbook.Na

7、medirname = Dir(lj & *.xls*Cells.ClearDo While dirname If dir name nm ThenWorkbooks.Ope n File name:=lj & & dir nameWorkbooks( nm .Activate復(fù)制新打開(kāi)工作簿的第一個(gè)工作表的已用區(qū)域到當(dāng)前工作表Workbooks(dirname.Sheets(1.UsedRa nge.Copy _ Ran ge(A65536.E nd(xlUp.Offset(1,0Workbooks(dir name.Close FalseEnd Ifdir name = DirLoopEn

8、d Sub簿中介紹過(guò)合并工作簿的示例。下面再列舉幾個(gè)示例,供有興趣的朋友參 考。的工作簿在“D示例數(shù)據(jù)記錄”文件夾中,含有兩個(gè)工作簿test1.xls、test2.xls(當(dāng)然,可以不限于兩個(gè),Read On ly:=True技巧91:匯總多個(gè)工作簿的工作表 所介紹的方法,即合并匯總。中一月.xls、二月.xls、三月.xls均只含有一張工作表且工作表中的數(shù)據(jù)均自單 元格A1開(kāi)始,現(xiàn)在要求將它們合并至中的值并將相應(yīng)單元格的值求和。中有多個(gè)工作簿,其中有一個(gè)用于匯總的工作簿,要求將除該匯總工作簿外的其 它工作簿中的第一張工作表的數(shù)據(jù)匯不限于兩個(gè),在test1.xls工作簿中含有三張工作表,在test2.xls

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論