前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >011 Ruby 多Word表写入Excel

011 Ruby 多Word表写入Excel

原创
作者头像
职场编码
修改2020-06-24 10:06:51
6650
修改2020-06-24 10:06:51
举报
文章被收录于专栏:Ruby办公自动化Ruby办公自动化

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

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

实现多表格快速汇总?

答案是肯定的。

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

001 需求分析

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

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

002 思路解析

解题思路:

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

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

003 代码展示

代码语言:ruby
复制
# 初始化
require "win32ole"

Pth=File.dirname(__FILE__)
Eap=WIN32OLE::new("Excel.Application")
Wap=WIN32OLE::new("word.Application");Wap.visible=true
arr=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=true
ebk.worksheets(1).range("a2").resize(s,5).value=arr

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 001 需求分析
  • 002 思路解析
  • 003 代码展示
相关产品与服务
腾讯云 BI
腾讯云 BI(Business Intelligence,BI)提供从数据源接入、数据建模到数据可视化分析全流程的BI能力,帮助经营者快速获取决策数据依据。系统采用敏捷自助式设计,使用者仅需通过简单拖拽即可完成原本复杂的报表开发过程,并支持报表的分享、推送等企业协作场景。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档