VBA代碼解決方案第二十六講:如何新建EXCEL工作簿文件

《VBA代碼解決方案》(版權10028096)這套教程是我最早推出的教程,目前已經是第三版修訂了。這套教程定位于入門后的提高,在學習這套教程過程中,側重點是要理解及掌握我的“積木編程”思想。要靈活運用教程中的實例像搭積木一樣把自己喜歡的代碼擺好。

這套教程共三冊,一百四十七講,內容覆蓋較廣,也是初級和中級間的過渡教程,改版后的內容主要是提供程序源碼文件及代碼修正為32位和64位兼用代碼。今后一段時間會給大家陸續推出。今日的內容是VBA代碼解決方案第二十六講:如何新建EXCEL工作簿文件

【分享成果,隨喜正能量】189 小小的善業,能贏來大的利益,小小的惡業,同樣也能招致嚴重的后果。這正如古語所云:“莫以善小而不為,莫以惡小而為之。。

第二十六講 如何新建EXCEL工作簿文件

各位好,今日我們講VBA代碼的第26講,如何新建EXCEL工作薄文件。對于工作薄的解釋,我們在之前的文章中已經講解過,要再復習一下,同時要注意工作薄和工作表的概念。工作薄是文件,工作表是工作薄的工作頁。在VBA中使用Add方法新建工作簿。

1 使用Workbooks對象的Add方法創建新工作簿

使用Workbooks對象的Add方法創建新工作簿,其語法為:

Workbooks對象.Add(Template)

參數Template可選,確定如何創建新工作簿。如果該參數指定的字符串是已有的Excel文件名,那么使用指定的文件作為模板創建新工作簿。如果該參數指定為xlWBATemplate常量之一,則新工作簿包含單個指定類型的工作表。如果忽略該參數,那么新工作簿包含標準的空工作表,可以使用SheetsInNewWorkbook屬性設置工作表數。

xlWBATemplate常量為:xlWBATChart,xlWBATExcel4IntlMacroSheet,xlWBATExcel4MacroSheet,xlWBATWorksheet。分別代表圖表工作表、宏工作表以及標準工作表。

2 新建EXCEL工作簿文件的實例代碼及代碼解讀

下面我們來詳細講解一下如何創建工作薄文件,如下面的代碼所示:

Sub mynz_26() '第26講 如何新建EXCEL工作簿文件

Dim Nowbook As Workbook

Dim ShName As Variant

Dim Arr As Variant

Dim i As Integer

Dim myNewWorkbook As Integer

myNewWorkbook = Application.SheetsInNewWorkbook

ShName = Array("余額數", "單價數", "數量", "金額數")

Arr = Array("1月", "2月", "3月", "4月", "5月", "6月", "7月", "8月", "9月", "10月", "11月", "12月")

Application.SheetsInNewWorkbook = 4

Set Nowbook = Workbooks.Add

With Nowbook

For i = 1 To 4

With .Sheets(i)

.Name = ShName(i - 1)

.Range("B1").Resize(1, UBound(Arr) + 1) = Arr

.Range("A2") = "品名"

End With

Next

.SaveAs Filename:=ThisWorkbook.Path & "\" & "庫存.xlsx"

.Close Savechanges:=True

End With

Set Nowbook = Nothing

Application.SheetsInNewWorkbook = myNewWorkbook

End Sub

代碼窗口:

代碼解析:mynz_26()過程使用Add方法建立新的工作簿并對新建工作簿進行操作。

1) 第2行到第6行代碼聲明變量類型。

2) 第7行代碼保存Excel自動插入到新工作簿中的工作表數目。

3) 第8、9行代碼將數組元素賦值給變量。

4) 第10行代碼將Application對象的SheetsInNewWorkbook屬性設置為4,表示在新建工作簿時插入4張工作表。

5) 第11行代碼使用Add方法建立新的工作簿,應用于Workbooks對象的Add方法新建工作簿,新建的工作簿將成為活動工作簿。

6) 第12行到第22行代碼操作新建工作簿。

7) 第15行到第17行代碼將新建工作簿的工作表進行重命名并給單元格賦值。

8) 第20行代碼使用SaveAs方法將新建工作簿重命名為“庫存.xls”保存在同一目錄中。

9) 第21行代碼使用Close方法關閉工作簿。

10) 第24行代碼恢復工作簿的默認設置。

代碼的運行結果:新添了文件“庫存”,內容如下:

今日內容回向:

1 ADD方法是什么?

2 .Range("B1").Resize(1, UBound(Arr) + 1) = Arr 是什么意義?

本講內容參考程序文件:VBA代碼解決方案修訂(1-48).xlsm

我20多年的VBA實踐經驗,全部濃縮在下面的各個教程中:



本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/87068.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/87068.shtml
英文地址,請注明出處:http://en.pswp.cn/web/87068.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

【unity游戲開發——網絡】套接字Socket的重要API

注意:考慮到熱更新的內容比較多,我將熱更新的內容分開,并全部整合放在【unity游戲開發——網絡】專欄里,感興趣的小伙伴可以前往逐一查看學習。 文章目錄 1、Socket套接字的作用2、Socket類型與創建3、核心屬性速查表4、關鍵方法指…

計算機網絡(二)應用層HTTP協議

目錄 1、HTTP概念 ?編輯2、工作流程?? 3、HTTP vs HTTPS?? 4、HTTP請求特征總結? 5、持久性和非持久性連接 非持久連接(HTTP/1.0)?? ??持久連接(HTTP/1.1)?? 1、HTTP概念 HTTP(HyperText Transfer …

c# IO密集型與CPU密集型任務詳解,以及在異步編程中的使用示例

文章目錄 IO密集型與CPU密集型任務詳解(C#示例)一、基本概念1. IO密集型任務2. CPU密集型任務 二、C#示例1. IO密集型示例1.1 文件操作異步示例1.2 網絡請求異步示例1.3 數據庫操作異步示例 2. CPU密集型示例2.1 基本CPU密集型異步處理2.2 并行處理CPU密…

用lines_gauss的width屬性提取缺陷

自己做了一個圖,這個圖放在資源里了 結果圖是這樣(這里只結算了窄區) 代碼和備注如下 read_image (Image11, C:/Users/Administrator/Desktop/分享/15/11.png) rgb1_to_gray (Image11, GrayImage) invert_image (GrayImage, ImageInvert) thr…

從0到100:房產中介小程序開發筆記(中)

背景調研 為中介帶來諸多優勢,能借助它打造專屬小程序,方便及時更新核實租賃信息,確保信息準確無誤,像房屋的大致地址、租金數額、租賃條件、房源優缺點等關鍵信息都能清晰呈現。還可上傳房屋拍攝照片,這樣用戶能提前…

【AI 時代的網絡爬蟲新形態與防護思路研究】

網絡爬蟲原理與攻擊防護的深度研究報告 網絡爬蟲技術已進入AI驅動的4.0時代,全球自動化請求流量占比突破51%,傳統防御手段在面對高度仿真的AI爬蟲時已顯疲態。基于2025年最新數據,深入剖析網絡爬蟲的基本原理、工作流程、分類與攻擊方式&…

低代碼平臺架構設計與關鍵組件

低代碼平臺的架構設計是其核心能力的關鍵支撐,需要平衡可視化開發的便捷性、生成應用的健壯性與性能、可擴展性以及企業級需求(如安全、多租戶、集成)。以下是一個典型的企業級低代碼平臺架構概覽及其關鍵組件: https://example.…

電商 ERP 系統集成接口指南

電商 ERP 系統的高效運行依賴于與多個業務系統的無縫對接,需要集成的核心接口包括:商品管理、訂單處理、庫存同步、物流配送、客戶管理、財務結算等。這些接口是實現數據互通、業務協同的關鍵橋梁。 一、電商 ERP 系統集成所需接口類型 (一…

Python實現對WPS協作群進行群消息自動推送

前言 本文是該專欄的第59篇,后面會持續分享python的各種干貨知識,值得關注。 相信有些同學在工作或者項目中,都會使用到“WPS協作”作為辦公聊天軟件。如果說,有些項目的監控預警正好需要你同步到WPS協作群,這個時候需要怎么去做呢? 而本文,筆者將基于WPS協作,通過Py…

js嚴格模式和非嚴格模式

好的,這是一個非常基礎且重要的概念。我們來詳細解析一下 JavaScript 中的嚴格模式(Strict Mode)和非嚴格模式(Sloppy Mode)。 可以把它想象成參加一場考試: 非嚴格模式:就像是開卷、不計時的…

板凳-------Mysql cookbook學習 (十一--------1)

第11章:生成和使用序列 11.0 引言 11.1 創建一個序列列并生成序列值 CREATE TABLE insect ( id INT UNSIGNED NOT NULL AUTO_INCREMENT, PRIMARY KEY (id),name VARCHAR(30) NOT NULL,date DATE NOT NULL,origin VARCHAR(30) NOT NULL); 字段說明 ?id…

Vue3 中 Excel 導出的性能優化與實戰指南

文章目錄 Vue3 中 Excel 導出的性能優化與實戰指南引言:為什么你的導出功能會卡死瀏覽器?一、前端導出方案深度剖析1.1 xlsx (SheetJS) - 輕量級冠軍1.2 exceljs - 功能強大的重量級選手 二、后端導出方案:大數據處理的救星2.1 為什么大數據需…

安卓RecyclerView實現3D滑動輪播效果全流程實戰

安卓RecyclerView實現3D滑動輪播效果全流程實戰 1. 前言 作為一名學習安卓的人,在接觸之前和之后兩種完全不同的想法: 好看和怎么實現 當初接觸到RecyclerView就覺得這個控件就可以把關于列表的所有UI實現,即便不能,也是功能十分強大 放在現在依然是應用最廣的滑動列表控…

電機控制——電機位置傳感器零位標定

在有感FOC算法中電機位置是一個重要的輸入,電機位置傳感器的作用就是測量電機的旋轉角度,通常是輸出sin(Theta)和cos(Theta)兩路模擬信號,根據這兩路模擬信號測得電機旋轉絕對角度。注意傳感器測量的是機械角度,不是電角度。 關于…

生物化學(實驗流程) PCR聚合酶鏈式反應: DNA 凝膠電泳實驗原理 實驗流程方法 實操建議筆記

凝膠電泳是分子生物學中最常用的技術之一,廣泛用于 DNA 片段的可視化、分離與識別。在獲取DNA 凝膠電泳相關設備(電泳設備 & DNA樣品染料 & 凝膠 & 染料)之后,可以考慮進行電泳操作。 整體電泳操作流程(從…

Python應用指南:利用高德地圖API獲取公交+地鐵可達圈(三)

副標題:基于模型構建器的批處理多份CSV轉換為點、線、面圖層 在地理信息系統(GIS)的實際應用中,我們經常需要處理大量以表格形式存儲的數據,例如人口統計數據、興趣點(POI)信息和監測站點記錄等…

每日算法刷題Day38 6.25:leetcode前綴和3道題,用時1h40min

5. 1749.任意子數組和的絕對值的最大值(中等,學習) 1749. 任意子數組和的絕對值的最大值 - 力扣(LeetCode) 思想 1.給你一個整數數組 nums 。一個子數組 [numsl, numsl1, ..., numsr-1, numsr] 的 和的絕對值 為 abs(numsl numsl1 ... numsr-1 nu…

創客匠人視角下創始人 IP 打造的底層邏輯與實踐路徑

在知識付費行業蓬勃發展的當下,創始人 IP 已成為連接用戶與商業價值的核心紐帶。創客匠人創始人老蔣在與行業頭部 IP 洪鑫的對話中揭示了一個關鍵命題:IP 打造的成敗,始于發心與理念的根基。從洪鑫教育中心營收超 6000 萬的案例來看&#xff…

2022/7 N2 jlpt詞匯

気力(きりょく) 清く(きよく) 記録(きろく) 記憶(きおく) 賢い(かしこい) 偉い(えらい) 凄い(すごい) 鋭い&am…

系統性能優化-8 TCP緩沖區與擁塞控制

每個 TCP 連接都有發送緩沖區和接收緩沖區,發送緩沖區存已發送未確認數據和待發送數據,接收緩沖區存接收但是沒有被上層服務讀取的數據。 # cat /proc/net/sockstat sockets: used 1885 TCP: inuse 537 orphan 0 tw 3 alloc 959 mem 10其中 mem 代表當前…