我正在使用 Rails 5。我想使用下面的代码解析 .xls(不要与 .xlsx doc 混淆)
book = Roo::Spreadsheet.open(file_location)
sheet = book.sheet(0)
text = sheet.to_csv
csv = CSV.parse(text)
arr_of_arrs = csv
text_content = ""
arr_of_arrs.each do |arr|
arr.map!{|v| v && v.to_f < 1 && v.to_f > 0 ? TimeFormattingHelper.time_as_str(v.to_f * 24 * 3600 * 1000) : v}
text_content = "#{text_content}\n#{arr.join("\t")}"
end
这是我上面引用的方法
def time_as_str(time_in_ms)
regex = /^(0*:?)*0*/
Time.at(time_in_ms.to_f/1000).utc.strftime("%H:%M:%S.%1N").sub!(regex, '')
end
我遇到问题的一个领域是我的 .xls 文档中出现的一个单元格
24:08:00
被处理为
1904-01-02T00:08:00+00:00
使用上面的代码。如何解析我在屏幕上看到的值?也就是说,如何将日期值转换为时间值?
作为另一个 Excel 文档的示例,显示为的单元格
24:02:00
被我上面的代码解析为
1899-12-31T00:02:00+00:00