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

012 Ruby Excel写入Word多表

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

这期,为你讲解如何将Excel数据依次写入Word多表。

001 需求分析

以下是两张表,1张源表,1张模板表。

Excel有效数据一共41行(不含标题)。

即,生成41个Word表。

002 思路解析

第一步,初始化。对各种对象变量进行赋值,主要有Word应用、Word文档、Excel应用、Excel工作簿、Excel有效行、Word表格数、数组arr、数组自增量i。

第二步,读入数组。我们通过这行代码,可以直接把工作表区域读入数组arr。

代码语言:javascript
复制
arr=Ebk.worksheets(1).usedrange.value

第三步,写入表格。我们通过这行代码,可以直接遍历数组依次写入Word表格。

代码语言:javascript
复制
Wdc.tables(i).cell(1,2).range.text=arr[i][0]

第四步,我们检查一下是否存在错误,保存即可。

003 代码展示

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

Pth=File.dirname(__FILE__)
Eap=WIN32OLE::new("Excel.Application");Eap.visible=true
Ebk=Eap.workbooks.open(Pth+'/火影.xls')
Wap=WIN32OLE::new("word.Application");Wap.visible=true
Wdc=Wap.documents.open(Pth+'/火影信息卡.doc')

n=Ebk.worksheets(1).usedrange.rows.count-2;i=1    
arr = Array;arr=Ebk.worksheets(1).usedrange.value

# 创建表格
Wap.selection.wholeStory                      
Wap.selection.copy  
n.times{
  Wap.selection.endKey                            
  Wap.selection.insertbreak(2)        
  Wap.selection.paste      
}
t=Wdc.tables.count;

# 写入Word表
(1..t).each{|i|
  Wdc.tables(i).cell(1,2).range.text=arr[i][0]
  Wdc.tables(i).cell(2,2).range.text=arr[i][1]
  Wdc.tables(i).cell(3,2).range.text=arr[i][2]
  Wdc.tables(i).cell(4,2).range.text=arr[i][3]
  Wdc.tables(i).cell(1,4).range.text=arr[i][4]
  Wdc.tables(i).cell(2,4).range.text=arr[i][5]
  Wdc.tables(i).cell(3,4).range.text=arr[i][6]
  Wdc.tables(i).cell(4,4).range.text=arr[i][7]
  i+=1
}

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

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

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

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

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 001 需求分析
  • 002 思路解析
  • 003 代码展示
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
http://www.vxiaotou.com