excel通过数据模板与vba批量制作csv数据表

所属分类: 软件教程 / 办公软件 阅读数: 1726
收藏 0 赞 0 分享

通过数据模板与VBA结合,批量制作CSV数据表,要求使用规则逐步递增的命名方式来命名批量制作出来的数据表,数据表的内容根据实际需求由最初的模板和提供的基础值自动生成。尽量减少手动操作,真正实现全自动!如图所示为批量制作出来的CSV数据表。

编辑数据模板,只要A2和B2单元格发生变化,其它相应的单元格就会通过引用公式来更新数据;

编辑好数据模板后,打开VBA编辑器,选择菜单“工具”——“宏”——“Visual Basic 编辑器”(快捷键为:Alt+F11);

插入用户窗体,在Visual Basic 编辑器菜单栏里选择“插入”——“用户窗体”,然后编辑用户窗体(该窗体作为模板基础数据录入部分),控件的具体使用稍微复杂一些,这里就不作介绍啦;

编辑窗体和控件代码,右击“UserForm1”——“查看代码”,在代码窗口录入相应的代码(由于这部分涉及的内容和步骤比较繁琐,只提供最终代码参考),代码如下:


复制代码
代码如下:

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 "数据处理成功!", vbOKOnly + 64, "提示"
Else
MsgBox "请核对数据信息!", 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函数替换成空白。
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函数替换成空白。
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函数替换成空白。
End Select
Next
End With
End Sub


编辑好窗体代码后,点击保存;

插入模块,该模块的作用是调出录入窗体(虽然窗体本身已经实现自动加载,但是不能实现二次自动加载),在Visual Basic 编辑器菜单栏里选择“插入”——“模块”,写入代码:

Sub 打开窗体()

UserForm1.Show

End Sub

模块代码录入完毕后,点击保存,然后关闭Visual Basic 编辑器;

回到数据表,调出录入窗体,选择菜单“工具”——“宏”——“宏”(快捷键为:Alt+F8)——选择“打开窗体”——“执行”;

按规定要求,录入基础数据,然后点击“确定”(一旦确定,VBA代码马上执行,将在桌面新建一个名为“Excel”的文件夹,在“Excel”文件夹里批量创建10个CSV工作簿,名称依次为Excel-1至Excel-10,内容也相应变化),确认“数据处理成功!”;

在桌面找到批量创建的CSV数据表,验证结果!

编辑代码的过程比较复杂,需要有足够的耐心,需要不断地去尝试和修改;

为了相关宏能正常运行,请把宏的安全性设置为最低级别。

更多精彩内容其他人还在看

ppt2003怎么输入角度符号?

ppt2003怎么输入角度符号?ppt2003中想要输入角度符号,但是没找到,该怎么输入?下面我们就来看看ppt输入特殊符号的教程,需要的朋友可以参考下
收藏 0 赞 0 分享

在Word文档中如何插入脚注呢?

整理word文档时,有时需要添加参考文献、注释等,这是就会用到插入注释功能,注释分为脚注和尾注,可分别选择,脚注插入在本页最下方,尾注插入在整个文档最后。那么在Word文档中如何插入脚注呢?下面就为大家介绍一下,来看看吧
收藏 0 赞 0 分享

在word文档中如何插入文件对象?

在Word文档中可以插入文本文件、Word文档、音乐视频文件等各种文件,并且也都可以直接打开,这个功能对于我们需要嵌套某个文件的Word文档来说,非常的实用,那么在word文档中如何插入文件对象?下面就为大家介绍一下,来看看吧
收藏 0 赞 0 分享

在excel中如何对某列单元格批量增加字符?

在excel使用中,有时需要对某列单元格进行增加字符,逐个添加过于繁琐,但是要如何批量操作呢?下面小编就为大家介绍在excel中如何对某列单元格批量增加字符方法,来看看吧
收藏 0 赞 0 分享

Excel如何隐藏行和列?excel行和列隐藏方法介绍

excel是一款强大的办公软件,其中隐藏行列就是比较方便的一个小功能,但是还是有很多不会灵活运用的朋友,那么Excel如何隐藏行和列?下面小编就为大家介绍excel行和列隐藏方法,来看看吧
收藏 0 赞 0 分享

PPT2016文字与图形之间怎么拆分合并?

PPT2016文字与图形之间怎么拆分合并?ppt中文字与图形经常拆分合并,该怎么操作呢?下面我们就来看看ppt拆分合并的使用方法,需要的朋友可以参考下
收藏 0 赞 0 分享

excel将文本转换为数字的四种方法

处理Excel表时,会发现有些数字却是文本格式,文本格式的数字是无法进行数字计算的,下面小编就为大家介绍excel将文本转换为数字的四种方法,来看看吧
收藏 0 赞 0 分享

word怎么去除页眉横线呢?

页眉横线一般在插入页眉后出现,有时也会在删除页眉页脚、页码后出现。如果有页眉,有这一条横线并不碍眼,但如果删除页眉页脚、页码后也有这条横线,那么word怎么去除页眉横线呢?下面小编就为大家介绍一下,来看看吧
收藏 0 赞 0 分享

Word怎么删除页面左边的竖线?

在Word使用过程中有时候会看到页面左边有一条竖线,这其实是在Word里开启了【修订】功能后产生的,那么这条竖线要怎么删除或取消呢?下面就为大家详细介绍一下,来看看吧
收藏 0 赞 0 分享

word怎么去掉边框呢?word边框删除方法介绍

有些网友放映在使用Word插入文本框的时候,经常会有一个方格,也就是文本框外面的黑色边框,想要去掉它,怎么办呢?下面小编就为大家介绍word边框删除方法,来看看吧
收藏 0 赞 0 分享
查看更多