Excel如何批量制作CSV数据表

众所周知,Excel的功能十分强大,而其最核心的功能在于数据处理。熟练驾奴Excel,您的工作将充满快乐和自信。当您仅花上几分钟就完成了别人花上几天功夫才能完成的数据处理工作时,心中的那份喜悦只有您自己才能体会得到!下面给大家展示的是Excel批量制作数据表……



目的

1通过数据模板与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数据表,验证结果!



注意事项

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



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

(0)

相关推荐

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

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

  • Excel表格怎么制作动态考勤表?

    excel制作考勤表很简单,该怎么制作动态考勤表呢?下面我们就来看看详细的教程. 1.在A3单元格输入‘=A2’(如图): 2.在B3单元格输入‘=A3+1’(如图): 3.在A4单元格输入‘=A3’ ...

  • excel中怎么制作库存盘点表?

    学会怎样用excel制作库存盘点表. 1.新建库存盘点工作表,输入内容. 2.把标题文字合并居中,文字设为宋体.16号. 3.如图所示把盘点项目等格式编辑好 4.输入序号.合计.制单人.保管人.监盘等 ...

  • excel中核对两个数据表数据差异

    excel中我们经常需要对比数据,excel也有很多方法帮助我们核对,找到一个合适的方法查找两个表的差异. 操作方法 01 我们以盘点数据与财务数据进行差异对比. 02 将光标定位在一个合适的位置存放 ...

  • Excel的高级筛选和数据表的区别

    我们工作中经常会遇到这种需求,有两个数据表,想要知道两个表的公共部分和独有部分,高级筛选就可以达到此目的。例如库房里有一个总的件号明细表,今天有一个销售明细表,想要知道今天销售的那些是库房里还有的,哪 ...

  • PPT2016如何把word/excel大纲批量制作成幻灯片

    在制作PPT过程中,如何把其他格式如Word或者Excle格式里的大纲批量制作成幻灯片呢?如下图所示的意思,下面让我们一起来看看吧 1.打开Word,选中里面的内容,先设置好大纲层次,如图所示 2.点 ...

  • PPT2016怎么把word/excel大纲批量制作成幻灯片?

    在制作PPT过程中,如何把其他格式如Word或者Excle格式里的大纲批量制作成幻灯片呢?如下图所示的意思,下面让我们一起来看看吧 1.打开Word,选中里面的内容,先设置好大纲层次,如图所示 2.点 ...

  • Excel中如何制作特殊数据标记的图表

    我们有时候会看到一些精美的图表中,数据标记是一些特殊的形状,是怎么实现的呢? 现在,我们就以折线图为例,讲解如何制作特殊数据标记的图表 操作方法 01 折线图已做好(请无视简陋),PNG格式的心形图也 ...

  • Excel如何批量提取全部工作表名称公式

    在使用公式查询或汇总多工作表数据时经常需要用到整个工作簿所有工作表的名称,下面介绍如何用宏表函数GET.WORKBOOK来提取工作表名称。 提取工作表名称过程: Ctrl+F3调出定义名称对话框,或者 ...