excel通過數(shù)據(jù)模板與vba批量制作csv數(shù)據(jù)表

通過數(shù)據(jù)模板與VBA結(jié)合,批量制作CSV數(shù)據(jù)表,要求使用規(guī)則逐步遞增的命名方式來命名批量制作出來的數(shù)據(jù)表,數(shù)據(jù)表的內(nèi)容根據(jù)實際需求由最初的模板和提供的基礎(chǔ)值自動生成。盡量減少手動操作,真正實現(xiàn)全自動!如圖所示為批量制作出來的CSV數(shù)據(jù)表。

編輯數(shù)據(jù)模板,只要A2和B2單元格發(fā)生變化,其它相應(yīng)的單元格就會通過引用公式來更新數(shù)據(jù);

編輯好數(shù)據(jù)模板后,打開VBA編輯器,選擇菜單“工具”——“宏”——“Visual Basic 編輯器”(快捷鍵為:Alt+F11);

插入用戶窗體,在Visual Basic 編輯器菜單欄里選擇“插入”——“用戶窗體”,然后編輯用戶窗體(該窗體作為模板基礎(chǔ)數(shù)據(jù)錄入部分),控件的具體使用稍微復(fù)雜一些,這里就不作介紹啦;

編輯窗體和控件代碼,右擊“UserForm1”——“查看代碼”,在代碼窗口錄入相應(yīng)的代碼(由于這部分涉及的內(nèi)容和步驟比較繁瑣,只提供最終代碼參考),代碼如下:
Private Sub CommandButton1_Click()
Dim n As Long
If TextBox1 <> "" And TextBox2 <> "" And TextBox3 <> "" And TextBox2 < TextBox3 Then
On Error Resume Next
MkDir CreateObject("WScript.Shell").SpecialFolders("Desktop") & "\" & TextBox1
For n = 1 To (TextBox3 - TextBox2 + 1) / 10
Sheets(1).Cells(2, 1).Value = TextBox1 & "-" & n
Sheets(1).Cells(2, 2).Value = TextBox2 + 10 * (n - 1)
ActiveWorkbook.SaveAs Filename:=CreateObject("WScript.Shell").SpecialFolders("Desktop") & "\" & TextBox1 & "\" & TextBox1 & "-" & n, FileFormat:=xlCSV, Password:="", WriteResPassword:="", ReadOnlyRecommended:=False, CreateBackup:=False
Next n
Unload Me
MsgBox "數(shù)據(jù)處理成功!", vbOKOnly + 64, "提示"
Else
MsgBox "請核對數(shù)據(jù)信息!", vbOKOnly + 64, "提示"
TextBox1.SetFocus
End If
End Sub
Private Sub CommandButton2_Click()
TextBox1 = ""
TextBox2 = ""
TextBox3 = ""
TextBox1.SetFocus
End Sub
Private Sub CommandButton3_Click()
Unload Me
End Sub
Private Sub TextBox1_Change()
Dim i%, Str$
With TextBox1
For i = 1 To Len(.Text)
Str = Mid(.Text, i, 1) '遍歷文本框中輸入的每一個字符。
Select Case Str
Case "a" To "z" '列出允許輸入的字符。
Case "A" To "Z" '列出允許輸入的字符。
Case Else
Beep
.Text = Replace(.Text, Str, "") '如果輸入的不是允許的字符,則使用Replace函數(shù)替換成空白。
End Select
Next
End With
End Sub
Private Sub TextBox2_Change()
Dim i%, Str$
With TextBox2
For i = 1 To Len(.Text)
Str = Mid(.Text, i, 1) '遍歷文本框中輸入的每一個字符。
Select Case Str
Case "0" To "9" '列出允許輸入的字符。
Case Else
Beep
.Text = Replace(.Text, Str, "") '如果輸入的不是允許的字符,則使用Replace函數(shù)替換成空白。
End Select
Next
End With
End Sub
Private Sub TextBox3_Change()
Dim i%, Str$
With TextBox3
For i = 1 To Len(.Text)
Str = Mid(.Text, i, 1) '遍歷文本框中輸入的每一個字符。
Select Case Str
Case "0" To "9" '列出允許輸入的字符。
Case Else
Beep
.Text = Replace(.Text, Str, "") '如果輸入的不是允許的字符,則使用Replace函數(shù)替換成空白。
End Select
Next
End With
End Sub
編輯好窗體代碼后,點擊保存;

插入模塊,該模塊的作用是調(diào)出錄入窗體(雖然窗體本身已經(jīng)實現(xiàn)自動加載,但是不能實現(xiàn)二次自動加載),在Visual Basic 編輯器菜單欄里選擇“插入”——“模塊”,寫入代碼:
Sub 打開窗體()
UserForm1.Show
End Sub
模塊代碼錄入完畢后,點擊保存,然后關(guān)閉Visual Basic 編輯器;

回到數(shù)據(jù)表,調(diào)出錄入窗體,選擇菜單“工具”——“宏”——“宏”(快捷鍵為:Alt+F8)——選擇“打開窗體”——“執(zhí)行”;

按規(guī)定要求,錄入基礎(chǔ)數(shù)據(jù),然后點擊“確定”(一旦確定,VBA代碼馬上執(zhí)行,將在桌面新建一個名為“Excel”的文件夾,在“Excel”文件夾里批量創(chuàng)建10個CSV工作簿,名稱依次為Excel-1至Excel-10,內(nèi)容也相應(yīng)變化),確認(rèn)“數(shù)據(jù)處理成功!”;

在桌面找到批量創(chuàng)建的CSV數(shù)據(jù)表,驗證結(jié)果!

編輯代碼的過程比較復(fù)雜,需要有足夠的耐心,需要不斷地去嘗試和修改;
為了相關(guān)宏能正常運行,請把宏的安全性設(shè)置為最低級別。
相關(guān)文章
word怎么單獨導(dǎo)出一頁? word導(dǎo)出部分頁的技巧
在編輯Word文檔時,有時我們只需要導(dǎo)出其中的部分頁面,而不是整個文檔,下面將介紹如何在Word中導(dǎo)出部分頁面2025-04-14問卷星怎么轉(zhuǎn)換成word文檔? 問卷星問卷調(diào)查導(dǎo)出成word的技巧
在日常工作中,我們經(jīng)常需要將問卷星上的問卷內(nèi)容導(dǎo)出為Word格式,以便整理和分析數(shù)據(jù),以下是三種簡單的操作方法2025-04-14word文檔一整頁怎么截屏? word文檔截圖截一張全的圖片技巧
在Word文檔中想將一整頁截屏下來,可以通過使用鍵盤中的Print Screen鍵和Word自帶的截屏功能等多種方法截圖,詳細如下2025-04-14word開發(fā)工具怎么調(diào)出來? word工具欄添加開發(fā)工具的教程
許多用戶在使用Word時,可能會發(fā)現(xiàn)菜單欄中缺少了“開發(fā)者工具”這一重要選項,這無疑限制了Word的某些高級功能應(yīng)用,詳細請看下文介紹2025-04-14陽歷/農(nóng)歷轉(zhuǎn)換對照表怎么做? Excel制作日歷表/萬年歷的最終版
想要制作陽歷/農(nóng)歷轉(zhuǎn)換對照表,,通過這個對照表,你只需知道陽歷日期,就可以快速準(zhǔn)確的找到對應(yīng)的農(nóng)歷日期,下面我們就來看看詳細制作方法2025-04-10- 工作上需要制作一個日歷表/萬年歷,該怎么制作呢?我們需要使用三個excel函數(shù)來實現(xiàn),詳細請看下文介紹2025-04-10
這個函數(shù)公式簡直太強了! excel按權(quán)重求和計算的技巧
Excel中有一個功能非常強大的函數(shù),它就是SUMPRODUCT函數(shù),既能求和、計數(shù)、權(quán)重計算,還能排名等,今天我們就來看看Excel根據(jù)權(quán)重求和的技巧2025-04-10tocol函數(shù)哪個版本能用? excel中tocol函數(shù)的兩種高級用法
TOCOL函數(shù)公式非常強大,值得一學(xué),從字面意義可以理解出來,它是將數(shù)據(jù)轉(zhuǎn)換成一列的,今天分享TOCOL函數(shù)的2種高級用法2025-04-10WPS的IF函數(shù)怎么使用? wps文檔運用if函數(shù)進行條件判斷的技巧
在wps的日常使用中,掌握IF函數(shù)的應(yīng)用將大大提高我們的工作效率,今天跟大家分享一下如何在WPS文字文檔表格中運用if函數(shù)進行條件判斷2025-04-09Office 365/2021更新后打開.doc文件頻繁崩潰怎么辦? 附滾回命令
Microsoft Word 365(以及 Word 2021)在打開.doc 文件時頻繁崩潰,僅能通過降級至舊版本臨時解決,下面我們就來看看滾回方法2025-04-08