011 Ruby 多Word表写入Excel

  |   0浏览

v2-51ad89f0cee4f34eb141d165e43ea3b2_720w.jpg

Hey,最近有很多粉丝私信询问,2020年已过半,又该统计半年报表信息了。

你关心的是,Ruby能否像VBA、Python一样,

实现多表格快速汇总?

答案是肯定的。

这期,为你讲解如何将多个Word表格汇总到Excel里。为了方便演示,我只模拟了3个Word数据文件。

v2-7ca045189cac1842b62af6eb9a7d26cd_720w.jpgv2-7573eea4f8d250be19e4798ea10cad21_720w.jpg

001 需求分析

v2-9f3c2b96b89dd46f5c41872e7b301590_720w.jpg

表格里有培训名称、培训时间、主办方、培训地点、培训内容等项目。

Word表和Excel大致存储原理大致相同,他们都是由一个个cell组成的,但不同的是,在Excel里单元格对象是cells,而在Word里它则变成了cell。

002 思路解析

v2-b31e8357860fe7b89e21ffff629dbecc_720w.jpg

解题思路:

第一步,通过Ruby调用Office接口,打开Word、Excel。

第二步,将Word表的指定位置数据写入数组保存。第三步,将数组数据一次性写入Excel保存。第四步,检查是否存在问题,关闭相关文件。

003 代码展示

# 初始化require 'win32ole'Pth=File.dirname(__FILE__)Eap=WIN32OLE::new('Excel.Application')Wap=WIN32OLE::new('word.Application');Wap.visible=truearr=Array.new(100){[nil]}filename=Dir.glob(Pth+'/*.doc')s=0# 提取文件filename.each{|n|    wdc=Wap.documents.open(n)    t=wdc.tables.count    (1..t).each{|i|        # 培训名称        arr[s][0]=wdc.tables(i).cell(1,2).range.text.chop        # 培训时间            arr[s][1]=wdc.tables(i).cell(1,4).range.text.chop        # 主持人        arr[s][2]=wdc.tables(i).cell(2,2).range.text.chop        # 培训地点        arr[s][3]=wdc.tables(i).cell(2,4).range.text.chop        # 培训内容        arr[s][4]=wdc.tables(i).cell(3,2).range.text.chop        s+=1    }    # wdc.close}# 数据写入ebk=Eap.workbooks.open(Pth+'/汇总.xls')Eap.visible=trueebk.worksheets(1).range('a2').resize(s,5).value=arr

原文地址:https://blog.51cto.com/14823672/2506729