可以实现插入文字,图像。
excel.rb代码如下
ruby 代码
- require 'win32ole'
- module Excel
- class WorkBook
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- @@worksheets_name =[]
- def initialize(encoding="GB2312")
- @excel = WIN32OLE.new("excel.application")
- @excel.visible = FALSE
- @workbook = @excel.Workbooks.Add()
-
- @encoding = encoding
- create_style
- end
- def add_worksheet(name)
- while @@worksheets_name.include?(name)
- name +="1"
- end
- @@worksheets_name << name
- worksheet = @workbook.Worksheets.Add()
- worksheet.Activate
- worksheet.name = name
- return WorkSheet.new(worksheet)
- end
- def show
- @excel.visible = TRUE
- end
- def close
- @workbook.Close(0)
- @excel.Quit()
- end
- def create_style
- sty=@workbook.Styles.Add('NormalStyle')
- sty.Font.Size = 12
- sty.Borders(7).LineStyle=1
- sty.Borders(8).LineStyle=1
- sty.Borders(9).LineStyle=1
- sty.Borders(10).LineStyle=1
-
- sty=@workbook.Styles.Add('TitleStyle')
- sty.Font.Size = 16
- sty.Font.Bold =true
- sty.Font.ColorIndex =3
-
- end
- end
-
- class WorkSheet
- IMAGE_ROW_NUM = 56
- @@worksheets_name =[]
- def initialize(worksheet)
- @row_count = 1
- @worksheet = worksheet
- end
- def add_space_line(n=1)
- return if n<1>
- @row_count +=n
- end
- def add_title(name)
- add_space_line
- add_row.add_cell(name,false,"TitleStyle")
- end
- def add_row()
- @current_row = Row.new(@worksheet,@row_count)
- @row_count +=1
- return @current_row
- end
- def current_row
- return @current_row
- end
- def add_image(image_path)
- if not File.exist?(image_path)
- return
- end
- add_space_line 1
- add_row
- cell_name=current_row.first_cell
- @worksheet.Range(cell_name).Select
- @worksheet.Pictures.Insert(image_path)
- add_space_line IMAGE_ROW_NUM
- end
- end
-
- class Row
- FILL_TYPE = 4
- @@cell_map =["A","B","C","D","E","F","G","H","I","J","K","L","M","N","O","P","Q","R","S","T","U","V","W","X","Y","Z"]
- def initialize(worksheet,row_id)
- @row_id =row_id
- @cell_count=0
- @worksheet = worksheet
- end
- def curent_cell
- return cell_name(@cell_count)
- end
- def first_cell
- return cell_name(0)
- end
- def add_cell(value,auto_fit = false,style = "NormalStyle")
- range = @worksheet.Range(cell_name(@cell_count))
- range['Value'] = value.to_s;
- range['Style']=style
- range.Columns.AutoFit if auto_fit
- @cell_count +=1
- end
- def cell_name(index)
- second = index % 26
- first = (index - second) / 26
- if first == 0
- return @@cell_map[second]+@row_id.to_s
- end
- first -=1
- return @@cell_map[first]+@@cell_map[second]+@row_id.to_s
- end
- def set_cell(index,value,auto_fit = false,style = "NormalStyle")
- range=@worksheet.Range(cell_name(index))
- range['Value'] = value;
- range['Style']=style
- range.Columns.AutoFit if auto_fit
- end
- end
- end
测试程序
ruby 代码
- require 'excel'
- excel = Excel::WorkBook.new
- worksheet = excel.add_worksheet("玛雅牛")
- worksheet.add_title('标题')
- row = worksheet.add_row
- row.add_cell("myaniu")
- row.add_cell(0)
- row.add_cell("2006-01-01 01:01:01")
- worksheet.add_image("C:\\AutoTest\\out.bmp")
- row = worksheet.add_row
- row.add_cell("玛雅牛")
- row.add_cell(0)
- row.add_cell("2006-01-01 01:01:01")
- worksheet.add_image("C:\\AutoTest\\out.bmp")
- excel.show
由于当时该程序是具有针对性,没有太考虑通用性,有些地方还是要修改。
分享到:
相关推荐
标题 "用ruby读excel文件生成xml文件" 描述的是一项技术任务,即使用Ruby编程语言来处理Excel文件,并将其内容转换成XML格式。这在数据迁移、格式转换或与不支持Excel格式的应用程序进行数据交换时非常有用。Ruby库...
以下是关于如何使用Ruby操作Excel的详细步骤和知识点: 1. **引入win32ole库** 首先,你需要在Ruby脚本的开头引入`win32ole`库。这行代码`require 'win32ole'`使得Ruby程序能够调用Excel的API。 2. **启动Excel...
从给定的文件标题、描述、标签以及部分内容中,我们可以提炼出以下详细的IT知识点,主要聚焦于使用Ruby语言对Excel文件进行操作。 ### 使用Ruby操作Excel的基础知识点 #### 1. 引入win32ole库 在Ruby中操作Excel,...
OneBox 是一个能够通过 url 生成图片预览的一个 ruby gem 库。 当前支持资源类型: 页面 图片 视频 该库设计之初为 http://www.discourse.org/ 使用,如今开源到 ...
使用ruby解析awdb离线库使用ruby解析awdb离线库使用ruby解析awdb离线库使用ruby解析awdb离线库使用ruby解析awdb离线库使用ruby解析awdb离线库使用ruby解析awdb离线库使用ruby解析awdb离线库使用ruby解析awdb离线库...
标题中的“ruby生成java文件的工具”指的是使用Ruby编程语言编写的一种工具,它能够自动生成Java源代码。这种工具通常用于提高开发效率,特别是在需要大量重复性代码的情况下,如数据访问对象(DAO)、控制器...
Ruby源代码,读写excel
使用RUBY语言将TXT文件中的内容写入到excel中!
**Ruby-GoOnRails:利用Rails生成器构建Golang应用** Ruby on Rails(简称Rails)是一种流行的Web开发框架,以其“约定优于配置”的理念和高效的开发速度受到开发者喜爱。而Go(Golang)则是一种静态类型、编译型的...
这样,无论你是使用 Rails 还是其他基于 Ruby 的框架,都能无缝集成这个代码生成器。 在实际应用中,Ruby-Autogeneratecode 可能会生成以下几种类型的代码: 1. 数据库迁移(Migrations):这些文件定义了数据库表...
RDoc是针对Ruby源代码的文档系统。跟JavaDoc一样,RDoc可以读取原文件,分析源代码中的语法信息和注释文本,生成HTML格式的文档。...应该可以使用ri命令来访问这些文档,不过这也取决于你安装Ruby的方式。
RoR是一个流行的开源Web开发框架,而Ruby语言本身支持与Microsoft Excel文件交互,这在数据导入导出、报表生成等场景中非常有用。 描述虽然简洁,但我们可以推断出它可能是指如何在Ruby中利用库来读取、写入或操作...
它使得开发者能够方便地创建清晰、结构化的代码注释,进而自动生成易于理解的API文档,帮助其他开发者理解和使用项目。在Ruby社区,文档的质量被视为项目成功的关键因素之一,RDoc为此提供了强大的支持。 RDoc的...
stream-ruby, ruby 客户端生成活动使用 GetStream.io 提供&流 流 ruby 是一款用于构建可以伸缩新闻发布和活动流的web服务的官方 ruby 客户端,它是流。注意,还有一个更高级的 Ruby on Rails - 流集成插件库,它将...
本篇文章将深入探讨如何使用Ruby来生成PDF,以及相关的库和工具。 Ruby社区提供了一些优秀的库,如Prawn和PDF::Writer,它们使得在Ruby中生成PDF变得简单。`genpdf.rb` 文件很可能是一个使用这些库之一编写的脚本...
由于想操作excel文件,对其的数据进行修改,但是因为没有office2003(价格原因)所以无法直接修改。所以调查了一下,有很多日本人做好的gem(spreadsheet.gem)可以直接拿来用。也就可以不安装office就可以对excel...
标题 "生成Ruby的离线文档" 指的是在没有互联网连接的情况下,为Ruby编程语言创建本地的完整文档集合。这对于开发者来说非常有用,因为它们可以在编写代码时快速查找API和函数信息,而无需依赖网络。 Ruby是一种...
RealRand - 使用 Ruby 生成真正的随机数。 密码学中的许多算法都依赖于良好的随机数,即“真正”随机的随机数,而不仅仅是由所谓的伪随机生成器生成的。 您无法使用计算机和算法创建真正的随机数。 只有大自然才能...
barby, ruby 条码生成器 BarbyBarby是一个 ruby 库,它以多种类型生成条码。它的功能分为条码和"输出"对象:[ Barby::Barcode objects] 符号将数据转换为给定符号的二进制表示形式。然后,使用这个表示并将它的转换...
在处理XML数据时,Ruby的REXML库能够解析和生成XML文档,支持XML数据的提取和操作。 总的来说,Ruby是处理文本数据的强大工具,它的字符串操作能力极其强大,且对处理CSV和XML等常见文本格式提供了现成的模块库。...