Как прочитать содержимое электронной таблицы Excel с помощью Ruby?
Я пытаюсь прочитать файл электронной таблицы Excel с помощью Ruby, но он не читает содержимое файла.
Это мой сценарий
book = Spreadsheet.open 'myexcel.xls';
sheet1 = book.worksheet 0
sheet1.each do |row|
puts row.inspect ;
puts row.format 2;
puts row[1];
exit;
end
Это дает мне следующее:
[DEPRECATED] By requiring 'parseexcel', 'parseexcel/parseexcel' and/or
'parseexcel/parser' you are loading a Compatibility layer which
provides a drop-in replacement for the ParseExcel library. This
code makes the reading of Spreadsheet documents less efficient and
will be removed in Spreadsheet version 1.0.0
#<Spreadsheet::Excel::Row:0xffffffdbc3e0d2 @worksheet=#<Spreadsheet::Excel::Worksheet:0xb79b8fe0> @outline_level=0 @idx=0 @hidden=false @height= @default_format= @formats= []>
#<Spreadsheet::Format:0xb79bc8ac>
nil
Мне нужно получить фактическое содержание файла. Что я делаю неправильно?
3 ответа
Это выглядит как row
чей класс Spreadsheet::Excel::Row
фактически Excel Range
и что оно включает в себя Enumerable или, по крайней мере, демонстрирует некоторые перечислимые поведения, #each
, например.
Таким образом, вы можете переписать ваш скрипт примерно так:
require 'spreadsheet'
book = Spreadsheet.open('myexcel.xls')
sheet1 = book.worksheet('Sheet1') # can use an index or worksheet name
sheet1.each do |row|
break if row[0].nil? # if first cell empty
puts row.join(',') # looks like it calls "to_s" on each cell's Value
end
Обратите внимание, что я заключил в скобки аргументы, что обычно рекомендуется в наши дни, и удалил точки с запятой, которые не нужны, если вы не пишете несколько операторов в строке (что вам следует делать редко - если вообще когда-либо - делать).
Это, вероятно, похмелье от более крупного скрипта, но я укажу, что в коде, приведенном book
а также sheet1
переменные на самом деле не нужны, и это Spreadsheet#open
занимает блок, так что более идиоматическая версия Ruby может выглядеть примерно так:
require 'spreadsheet'
Spreadsheet.open('MyTestSheet.xls') do |book|
book.worksheet('Sheet1').each do |row|
break if row[0].nil?
puts row.join(',')
end
end
Я не думаю, что вам нужно требовать parseexcel, просто require 'spreadsheet'
Вы прочитали руководство, это очень легко следовать.