【问题标题】:Getting spreadsheet row count using spreadsheet gem使用电子表格 gem 获取电子表格行数
【发布时间】:2013-06-06 13:05:30
【问题描述】:

这是我当前的工作代码:

require 'csv'
require 'spreadsheet'

folder_to_analyze = ARGV.first
folder_path = File.join(Dir.pwd, folder_to_analyze)

unless File.directory?(folder_path)
  puts "Error: #{folder_path} no es un folder valido."
  exit
end

def get_csv_file_paths(path)
  Dir.glob(path + '/**/*.csv').each do |f|
    yield f
  end
end

def get_xls_file_path(path)
  Dir.glob(path + '/**/*.xls').each do |f|
    yield f
  end
end

csv_files = []
excel_files = []
get_csv_file_paths(folder_path) { |f| csv_files << f }
get_xls_file_path(folder_path) { |f| excel_files << f }

puts "Se encontro #{csv_files.length + excel_files.length} archivos para procesar."

puts '==========================================='
puts 'Archivos CSV:'
puts '==========================================='
csv_files.each do |f|
  count = IO.readlines(f).size
  puts "Archivo: #{File.basename(f)} - Correos: #{count}"
end

puts '==========================================='
puts 'Archivos Excel:'
puts '==========================================='
Spreadsheet.client_encoding = 'UTF-8'
excel_files.each do |f|
  count = 0

  book = Spreadsheet.open f
  book.worksheets.each do |sheet|
    sheet.each do |row|
     count = count + 1
    end
  end

  puts "Archivo: #{File.basename(f)} - Correos: #{count}"
end

电子表格的行数计算非常慢,每个 excel 文件大约需要 4 秒来计算。

有什么方法可以加快速度吗?它是否在某处隐藏了 row_count 属性?

【问题讨论】:

    标签: ruby excel count row spreadsheet


    【解决方案1】:

    无需遍历工作表的行,只需像这样在每个工作表上调用 count

    excel_files.each do |f|
      count = 0
    
      book = Spreadsheet.open f
      book.worksheets.each do |sheet| 
         count += sheet.count
      end
    
      puts "Archivo: #{File.basename(f)} - Correos: #{count}"
    end
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2023-03-29
      • 1970-01-01
      • 2017-03-02
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多