Sha256: a86764a0916d2dc349cd2c0cd0961cf93b87ac4e41433da0519b2397d633778a
Contents?: true
Size: 1.5 KB
Versions: 13
Compression:
Stored size: 1.5 KB
Contents
require 'roo/excelx/extractor' module Roo class Excelx class Workbook < Excelx::Extractor class Label attr_reader :sheet, :row, :col, :name def initialize(name, sheet, row, col) @name = name @sheet = sheet @row = row.to_i @col = ::Roo::Utils.letter_to_number(col) end def key [@row, @col] end end def initialize(path) super fail ArgumentError, 'missing required workbook file' unless doc_exists? end def sheets doc.xpath('//sheet') end # aka labels def defined_names Hash[doc.xpath('//definedName').map do |defined_name| # "Sheet1!$C$5" sheet, coordinates = defined_name.text.split('!$', 2) col, row = coordinates.split('$') name = defined_name['name'] [name, Label.new(name, sheet, row, col)] end] end def base_date @base_date ||= begin # Default to 1900 (minus one day due to excel quirk) but use 1904 if # it's set in the Workbook's workbookPr # http://msdn.microsoft.com/en-us/library/ff530155(v=office.12).aspx result = Date.new(1899, 12, 30) # default doc.css('workbookPr[date1904]').each do |workbookPr| if workbookPr['date1904'] =~ /true|1/i result = Date.new(1904, 01, 01) break end end result end end end end end
Version data entries
13 entries across 13 versions & 1 rubygems