簡體   English   中英

NoMemoryError:無法分配內存

[英]NoMemoryError: failed to allocate memory

我有一個包含大量數據的xlsx文件,並且我有此腳本可以將xlsx文件中的數據插入到我自己的數據庫中:

file = 'lib/assets/sicepatfull.xlsx'
xlsx = Roo::Spreadsheet.open(file)
sheet = xlsx.sheet(0)
attrs = sheet.row(1)
data = sheet.parse(header_search: attrs).map do |d|
  d.map {|k, v| [k.parameterize.underscore.to_sym, v] }.to_h.except :id
end
Courier.create!(data)

attrs之后取消該命令,結果是: NoMemoryError: failed to allocate memory

我如何解決它?

Roo將整個文件加載到內存中,因此,如果文件很大,可能對您的RAM來說太大了。

您可以使用其他XLSX閱讀器,例如

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM