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

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

編輯數(shù)據(jù)模板,只要A2和B2單元格發(fā)生變化,其它相應(yīng)的單元格就會(huì)通過引用公式來更新數(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 "請(qǐng)核對(duì)數(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) '遍歷文本框中輸入的每一個(gè)字符。
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) '遍歷文本框中輸入的每一個(gè)字符。
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) '遍歷文本框中輸入的每一個(gè)字符。
Select Case Str
Case "0" To "9" '列出允許輸入的字符。
Case Else
Beep
.Text = Replace(.Text, Str, "") '如果輸入的不是允許的字符,則使用Replace函數(shù)替換成空白。
End Select
Next
End With
End Sub
編輯好窗體代碼后,點(diǎn)擊保存;

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

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

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

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

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