http://www.won-soft.com/macro/solution/excel-data-replace.htm
介绍:
在我们的日常工作中, 可能经常需要使用同各种数据表格打交道.比如财务工作中各种数据表格, 生产管理上的各种生产数据统计表,以前人力资源部的工资表等等。在处理这些数据的过程中, 我们可能经常会遇到要做一张表,但这张表的数据需要从另一张表上取,每个数据间有一些相关联的规则,举例来说: 年底一般都会做工资统计表,列出所有员工的全年的各种奖金总计、全年应发工资、实发工资、扣款等等项目。这些数据 可能分散在几张表中, 每张表上都有员工的姓名和银行帐号,我们需要根据员工姓名或是银行帐号从各表上取数字, 然后填在统计表。一般我们都是通过在表间查找,然后使用复制/粘贴的方法来完成这类数据替换,如果数据一多,这个 工作的强度是可想而知的。这里我们来看看自动操作魔法师能不能帮我们减化甚至代替我们完成这种数据替换工作。
分析:
我们先来梳理一下表格间数据替换的基本步骤,这里我们假设有两张表,A和B,A表里面有人员姓名、银行帐号、全年工资合计、奖金合计,其中奖金合计这一栏需要从B表中来,B表里面有人员姓名和奖金合计:
- 首先定义需要使用的变量;
- 首先我们打开两张表;
- 从A表里面取一个人员姓名.
注意:如果没有人员姓名了,直接退出,否则没完了。 - 从B表里面根据姓名查奖金合计.
- 如果找到了,则将奖金数粘贴到A表中的奖金合计一栏内.
- 将行号加1,并且跳到第3步继续下一行数据的替换。
自动操作魔法师增强版支持Microsoft Excel文档处理命令,可以对某个单元格进行读或者写,还支持查找单元格数据。 同时,自动魔法师支持循环和跳转指令,可以看出,我们可以使用这些命令来模拟表格间的数据替换操作过程.现在我们就试着根据上面的步骤建立一个脚本来完成此项工作.
建立步骤:
第一步: 建立一个空白魔法
首先,打开"魔法管理器",点击菜单“魔法”,选择“建立一个空白魔法”,如下图:
点击菜单项后,魔法"属性"对话框将会弹出来让我们指定新魔法的一些属性,我们给魔法取一个名称"表格间数据替换",然后点击"确定"直接建立魔法。如下图:
这时自动操作魔法师会弹出一个对话框询问是否编辑这个魔法,我们选择“是”进入编辑器。
魔法编辑器打开后,我们根据前面列出的步骤来一步步插入需要的命令.
第二步: 设置变量
首先,需要定义多个变量用于指定读取的行数,保存读取的内容等等。点击编辑器的菜单"变量",再选择“增加一个变量”,依次加入变量“v_行号”, “v_姓名”,“v_找到的行号”,“v_结束”,“v_奖金”.
变量加入后,我们还需要对"v_行号"设置初始值,点击菜单"插入",选择"变量类",选择"设置变量值", 将变量值设为2(我们的数据在A表中是从第二行开始的)。
第三步: 打开两张表
点击编辑器的菜单"插入", 选择“文档类”,最后选择“打开文档”,如下图:
在命令选项窗口内,输入A表的路径,如:a.xls,文档标识名处我们输入:"A表",文档标识名是用来表示 文档的,在后续对A表的操作中,我们都需要指定这个名称表示是处理A表的。设置完成后,点击确定,如下图:
现在我们还需要打开B表.再次点击"插入"菜单加入"打开文档"命令,且使用使用"B表"做为文档标识名.
第四步: 从A表里面取一个人员姓名
首先,我们在这里插入一个标号(标号是结合跳转命令用的,用来指定需要跳到什么地方),这个标号将在最后跳转时使用。
点击编辑器的菜单"插入",选择“流程类”,再选择"标号",并设一个名称,如下图:
点击编辑器的菜单"插入", 选择“文档类”,选择“读Excel文档单元格”,设置好相关参数,如下图:
因为需要替换的数据不只一个,所以这里单元格行使用变量"v_行号"来代替,而不用具体的数字.读出的内容我们放入变量"v_姓名"中。
第五步: 判断是否已经读完所有数据
点击编辑器的菜单"插入",选择“流程类”,再选择"条件判断(根据变量值)",判断变量"v_结束"是否为1。如下图:
并且在条件判断里面加入"结束"(点击菜单"插入",选择"播放控制类"里面的“结束”。如下图:
第六步: B表里面根据姓名查奖金合计
点击编辑器的菜单"插入", 选择“文档类”,选择“查找EXCEL文档单元格”,设置好相关参数,如下图:
这里我们将使用"v_姓名"来代替要查找的内容,并将找到的行号返回到变量"v_找到的行号"中。
第七步: 读出奖金数据
点击编辑器的菜单"插入", 选择“文档类”,选择“读取EXCEL文档单元格”,将B表中的C列读出来放入"v_奖金"中。
第八步: 将B表里面的奖金合计数放到A表中
点击编辑器的菜单"插入",选择“文档类”,选择“写EXCEL文档单元格”,读取刚才查到的人员奖金数,如下图:
第九步: 跳转到开始
命令执行到这里,我们只完成了一行数据的替换,所以我们还需要做一些额外的工作继续完成所有的数据替换。点击编辑器的菜单"插入",选择“变量类”, 选择“设置变量值”,将变量"v_行号"+1,这样以便替换下一行数据。如下图:
然后,我们再加一条跳转命令,跳到"读人员姓名"处。如下图:
结束:
到此,我们的数据替换魔法已经建立好了。