Как прочитать содержимое электронной таблицы Excel с помощью Ruby? - PullRequest
14 голосов
/ 22 июля 2010

Я пытаюсь прочитать файл таблицы 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 ]

21 голосов
/ 22 июля 2010

Похоже, 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
4 голосов
/ 22 июля 2010

Я не думаю, что вам нужно запрашивать parseexcel, просто require 'spreadsheet'

Читали ли вы руководство , за ним очень легко следить.

0 голосов
/ 22 июля 2010

Это файл в одну строку? Если так, то вам нужно:

puts row[0];
...