excel通过数据模板与vba批量制作csv数据表
发布时间:2022-11-16 20:23:20
通过数据模板与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数据表,验证结果!
编辑代码的过程比较复杂,需要有足够的耐心,需要不断地去尝试和修改;
为了相关宏能正常运行,请把宏的安全性设置为最低级别。


猜你喜欢
- 现在很多小伙伴电脑上使用的办公软件已经从office转换成WPS了,你真的了解WPS吗?小编今天给大家带来WPS3种分享权限的介绍,一起来学
- 在Excel众多的功能中,填充数据的运用只是其中很小的一块,对于这个朋友们都经常使用到的功能,它到底能为大家的出色工作加分多少?今天,小编就
- 我们工作的时候,有时我们按列进行排序,可能因为工作的变动,我们又要修改成按行进行排序,那么在excel表格中怎么将行变成列?下面小编就为大家
- 当我们使用win10系统时,可以通过任务栏设置来对任务栏进行设置,而最近有不少小伙伴反应,自己的电脑为什么win10任务栏设置打不开?这时候
- 今天收到一封邮件,邮件里的word文档,打开时提示“word无法启动转换器mswrd632.wpc”(如下图),点击确定后,word文档变成
- IMovie是一款非常好用的视频剪辑软件,它可以根据你的要求剪出你想要的视频效果,还有给视频加滤镜、加字幕等功能,那么IMovie怎么给视频
- 装订线是指蜡线、丝线、麻线、合成纤维线等装订材料。在制作试卷时,我们经常需要制作一条密封的装订线,用来提醒考生回答问题时不要超过这条线。那么
- proxifier是部分用户会接触到的代理服务器软件,用户使用这款软件就可以不受限制的使用自己喜欢的软件了,当然用户在刚开始接触时会有些困难
- 用户可以为 iPhone、iPad 和 Mac 上的每个日历设置不同的颜色。通过这种方式,您可以借助颜色轻松查看某个约会是私人约会、工作约会
- 任务栏就是桌面最下方的小长条,主要由开始菜单、快速启动栏等组成,如果想要调整任务栏宽度却不知道如何调整,其实不仅可以调整宽度还可以调整位置,
- 如果 Mac 或触控键盘配备了触控 ID,您可以使用触控 ID 来解锁 Mac、授权从 iTunes Store、App Store 和 A
- 打开需要添加页码的文档 2.点击工具栏的“插入”然后插入“页码”。3.页码的插入方式有10种,我们可以将页码插在页
- 很多人对XP系统的使用习惯根深蒂固,在用上新系统后都想延续曾经的使用习惯,比如使用快速启动栏。在最新的Win10系统上,我们如何才能在任务栏
- 这篇文章主要是向脚本之家的朋友介绍利用Excel和bat批处理命令快速批量创建指定文件夹方法,教程真的很不错,很值得大家学习,推荐到脚本之家
- Excel中经常需要给数据进行一个换行的操作,数据具体该如何进行换行呢?下面是由小编分享的excel表格数据换行的教程,以供大家阅读和学习。
- 在日常办公室经常要填写各类表格,有些表格对内容有着严格的规范化要求,为了使表格内容填写规范,我们可以使用wps的窗体控件来实现。那么具体怎么
- 传统电脑产品受到手机挤压已经是不争的事实,而类PC的平板也在近两年出现下滑趋势,看起来移动市场仍将在未来占据主导地位。不过,这并非说明电脑类
- Camera Raw中的 “ 斑点去除”工具允许您通过从同一图像的不同区域进行采样来修复图像的选定区域。其默认行为使您可以通过在照片上拖动画
- Win10任务栏看不到正在运行的图标但能点到是怎么回事?任务栏下图标消失不见,应用其实在后台运行,遇到这种情况该如何解决?Win10任务栏看
- GROWTH函数用于根据现有的数据预测指数增长值。根据现有的x值和y值,GROWTH函数返回一组新的x值对应的y值。可以使用GROWTH工作