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 代码展示

# 初始化
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.chops+=1}# wdc.close
}# 数据写入
ebk=Eap.workbooks.open(Pth+'/汇总.xls')
Eap.visible=true
ebk.worksheets(1).range("a2").resize(s,5).value=arr

open表和closed表_011 Ruby 多Word表写入Excel相关推荐

  1. oracle外部表使用详解,详解Oracle外部表的一次维护(图文)

    在做Oracle数据库的导出导入操作的时候,发现在将导出数据导入到新库过程中报告如下错误: 在查看数据库中关于外部表的视图中相关信息:select * from dba_directoriesSele ...

  2. 数据库表(字段类型、约束、截断表、修改表字段、重命名表)

    字段类型: 在这里只列举一些常用的字段类型: 整数类型:int(Integer):普通大小的整数 小数类型: float(m,d):单精度浮点数,m表示数字长度,d表示小数位数,例如float(5,2 ...

  3. 涉密计算机用户账号设置审批表,北京邮电大学涉密计算机配置审批表.PDF

    北京邮电大学涉密计算机配置审批表 北京邮电大学涉密计算机配置审批表 使用部门 品牌型号 涉密计算机类型 ?台式机 ?便携机 资产编号 用途 ?科研 ?办公 ?其他 配置日期 硬盘序列号 中央处理器 硬 ...

  4. Python将MySQL表数据写入excel

    背景:将mysql表查询结果写入excel. 1.使用sqlyog工具将查询结果导出到Excel.xml中,用excel打开发现:因为text字段中有回车换行操作,显示结果行是乱的. 2.用mysql ...

  5. 【数据结构】邻接表的储存结构 建立图的邻接表算法

    [数据结构]邻接矩阵及其实现 一个图的邻接矩阵的表示是唯一的,但其邻接表表示不唯一,这是因为在邻接表结构中,各便表结点的链接次序取决于建立邻接表时的算法以及输入的次序. 一般而言邻接矩阵适合存储稠密图 ...

  6. python提交表单无效_使用Django Form解决表单数据无法动态刷新的两种方法

    一.无法动态更新数据的实例 1. 如下,数据库中创建了班级表和教师表,两张表的对应关系为"多对多" from django.db import models class Class ...

  7. R语言write.xlsx函数将数据写入Excel文件:写入Excel文件并自定义表单的名称、将数据写入Excel文件新的表单(sheet)中、将文件保存为xls文件格式(而不是xlsx)

    R语言write.xlsx函数将数据写入Excel文件:写入Excel文件并自定义表单的名称.将数据写入Excel文件新的表单(sheet)中.将文件保存为xls文件格式(而不是xlsx) 目录

  8. 2020身高体重标准表儿童_2020年儿童标准身高体重表发布,对比看看,你家孩子达标了吗?...

    下载好向圈APP可以快速联系圈友 您需要 登录 才可以下载或查看,没有帐号?立即注册 x 说起孩子的身高,恐怕没有父母不关注.尤其到了春天,长高的"黄金季"来了,都恨不得孩子在这个 ...

  9. navcat设置oracle表主键自增_初识 Oracle 表空间设置与管理

    本文出自头条号老王谈运维,转载请说明出处. 前言 表空间是 Oracle 特有的一种逻辑结构,是管理和组织 Oracle 数据文件一种方式,一个Oracle 数据库能够有一个或多个表空间,而一个表空间 ...

最新文章

  1. 院士:人一生有两个阶段最能逼出成果,一是拿博士学位,二是评正教授
  2. Delphi 原生ADO(二)
  3. 百度和360的关键词提交查询
  4. 如何获取版本的 Internet 信息服务器 (IIS)
  5. 表示微型计算机系统稳定性,计算机基础知识(三)135
  6. Linux C高级编程——目录操作
  7. Visual Studio 类视图和“对象浏览器”图标含义
  8. shiro 跨域登录_六个高Star开源项目,让你更懂OAuth和单点登录
  9. .Net/C# 实现真正的只读的 Hashtable 类型的属性 (ReadOnly Hashtable Property)
  10. 百度商桥放在php网站哪里_网站优化的几个重要技巧,你知道吗?
  11. 经典网络结构 (五):ResNet (残差网络)
  12. ubuntu打开网易云音乐
  13. python中如何显示特殊的单位符号
  14. 星际争霸 vs 魔兽争霸3 vs 红警完全对比
  15. echart添加文本_ECharts自定义富文本
  16. dfs——xy省赛选拔题——问题 E: 整数凑和问题
  17. Django新增数据
  18. Redis的五种基础数据结构和三种高级数据结构
  19. Mac Xcode崩溃 (打开ios项目引起崩溃)
  20. c 传递流java 生僻字_Java语言中的生僻知识

热门文章

  1. 解决spring和struts配合问题
  2. 牛客16785 Cantor表
  3. 线程同步-事件内核对象
  4. mysql内部实现原理面试_理解完这些基本上能解决面试中MySql的事务问题
  5. Hadoop分布式集群搭建详细过程
  6. 算法实现:返回单链表的倒数第pos个节点
  7. 大数据技术Hbase 和 Hive 详解
  8. 链表简单实现(增删查改)
  9. 简明Python教程学习笔记_3_模块
  10. SpringBoot 自带工具类~StringUtils