class RubyXL::Workbook
Constants
- APPLICATION
- APPVERSION
- CONTENT_TYPE
- CONTENT_TYPE_WITH_MACROS
- DATE1899
Subtracting one day to accomodate for erroneous 1900 leap year compatibility only for 1900 based dates
- DATE1904
- MARCH_1_1900
- REL_TYPE
- SHEET_NAME_FORBIDDEN_CHARS
www.accountingweb.com/technology/excel/seven-characters-you-cant-use-in-worksheet-names
Attributes
worksheets[RW]
Public Class Methods
new(worksheets = [], src_file_path = nil, creator = nil, modifier = nil, created_at = nil, company = '', application = APPLICATION, appversion = APPVERSION, date1904 = 0)
click to toggle source
Calls superclass method
RubyXL::OOXMLObjectInstanceMethods.new
# File lib/rubyXL/objects/workbook.rb, line 432 def initialize(worksheets = [], src_file_path = nil, creator = nil, modifier = nil, created_at = nil, company = '', application = APPLICATION, appversion = APPVERSION, date1904 = 0) super() # Order of sheets in the +worksheets+ array corresponds to the order of pages in Excel UI. # SheetId's, rId's, etc. are completely unrelated to ordering. @worksheets = worksheets add_worksheet if @worksheets.empty? @theme = RubyXL::Theme.default @shared_strings_container = RubyXL::SharedStringsTable.new @stylesheet = RubyXL::Stylesheet.default @relationship_container = RubyXL::OOXMLRelationshipsFile.new @root = RubyXL::WorkbookRoot.default @root.workbook = self @root.source_file_path = src_file_path creation_time = DateTime.parse(created_at) rescue DateTime.now self.created_at = creation_time self.modified_at = creation_time self.company = company self.application = application self.appversion = appversion self.creator = creator self.modifier = modifier self.date1904 = date1904 > 0 end
Public Instance Methods
before_write_xml()
click to toggle source
# File lib/rubyXL/objects/workbook.rb, line 361 def before_write_xml max_sheet_id = worksheets.collect(&:sheet_id).compact.max || 0 self.sheets = RubyXL::Sheets.new worksheets.each { |sheet, i| rel = relationship_container.find_by_target(sheet.xlsx_path) raise "Worksheet name '#{sheet.sheet_name}' contains forbidden characters" if sheet.sheet_name =~ SHEET_NAME_FORBIDDEN_CHARS sheets << RubyXL::Sheet.new(:name => sheet.sheet_name[0..30], # Max sheet name length is 31 char :sheet_id => sheet.sheet_id || (max_sheet_id += 1), :state => sheet.state, :r_id => rel.id) } true end
content_type()
click to toggle source
# File lib/rubyXL/objects/workbook.rb, line 311 def content_type if macros then CONTENT_TYPE_WITH_MACROS else CONTENT_TYPE end end
date_to_num(date)
click to toggle source
# File lib/rubyXL/objects/workbook.rb, line 414 def date_to_num(date) date && (date.ajd - base_date().ajd).to_f end
num_to_date(num)
click to toggle source
# File lib/rubyXL/objects/workbook.rb, line 418 def num_to_date(num) # Bug-for-bug Excel compatibility (https://support.microsoft.com/kb/214058/) if num && num < MARCH_1_1900 then num += 1 unless workbook_properties && workbook_properties.date1904 end num && (base_date + num) end
save(dst_file_path = nil)
click to toggle source
Save the resulting XLSX file to the specified location
# File lib/rubyXL/objects/workbook.rb, line 390 def save(dst_file_path = nil) dst_file_path ||= root.source_file_path extension = File.extname(dst_file_path) unless %w{.xlsx .xlsm}.include?(extension.downcase) raise "Unsupported extension: #{extension} (only .xlsx and .xlsm files are supported)." end File.open(dst_file_path, "wb") { |output_file| FileUtils.copy_stream(root.stream, output_file) } return dst_file_path end
Also aliased as: write
stream()
click to toggle source
Return the resulting XLSX file in a stream (useful for sending over HTTP)
# File lib/rubyXL/objects/workbook.rb, line 385 def stream root.stream end
xlsx_path()
click to toggle source
# File lib/rubyXL/objects/workbook.rb, line 380 def xlsx_path ROOT.join('xl', 'workbook.xml') end