Sha256: 79168cc96d9f830e43cbfda30568274da236b1afac18f3aaba65414a69adca49
Contents?: true
Size: 1.57 KB
Versions: 2
Compression:
Stored size: 1.57 KB
Contents
require 'csv' module IOStreams module Xlsx class Reader attr_reader :worksheet # Read from a xlsx, or xlsm file or stream. # # Example: # IOStreams::Xlsx::Reader.open('spreadsheet.xlsx') do |spreadsheet_stream| # spreadsheet_stream.each_line do |line| # puts line # end # end def self.open(file_name_or_io, options={}, &block) begin require 'creek' unless defined?(Creek::Book) rescue LoadError => e raise(LoadError, "Please install the 'creek' gem for xlsx streaming support. #{e.message}") end options = options.dup buffer_size = options.delete(:buffer_size) || 65536 raise(ArgumentError, "Unknown IOStreams::Xlsx::Reader option: #{options.inspect}") if options.size > 0 if IOStreams.reader_stream?(file_name_or_io) temp_file = Tempfile.new('rocket_job_xlsx') file_name = temp_file.to_path ::File.open(file_name, 'wb') do |file| IOStreams.copy(file_name_or_io, file, buffer_size) end else file_name = file_name_or_io end block.call(self.new(Creek::Book.new(file_name, check_file_extension: false))) ensure temp_file.delete if temp_file end def initialize(workbook) @worksheet = workbook.sheets[0] end # Returns each [Array] row from the spreadsheet def each(&block) worksheet.rows.each { |row| block.call(row.values) } end alias_method :each_line, :each end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
iostreams-0.9.1 | lib/io_streams/xlsx/reader.rb |
iostreams-0.9.0 | lib/io_streams/xlsx/reader.rb |