CSV.open(name, "r").each do |row|
puts row
end我得到了以下错误:
CSV::MalformedCSVError Unquoted fields do not allow \r or \n 文件的名称是.txt制表符分隔的文件。我特意做的。我有一个.csv文件,我去excel,并将文件保存为以.txt制表符分隔的文件。因此它是制表符分隔的。
CSV.open不应该能够读取制表符分隔的文件吗?
发布于 2015-07-24 23:40:39
尝试按如下方式指定字段分隔符:
CSV.open("name", "r", { :col_sep => "\t" }).each do |row|
puts row
end记住要使用require 'csv'并阅读DOCS
发布于 2015-07-24 23:40:04
默认情况下,CSV使用逗号作为分隔符,这是因为CSV代表“逗号分隔值”。
如果你想要一个不同的分隔符(在本例中是制表符),你需要显式地使用它。
示例
p CSV.new("aaa\tbbb\tccc\nddd\teee", col_sep: "\t").read相关文档:http://ruby-doc.org/stdlib-2.1.0/libdoc/csv/rdoc/CSV.html#new
发布于 2021-10-31 23:58:40
作为CSV的替代方案,您也可以像这样使用smarter_csv:
require 'smarter_csv'
data = SmarterCSV.process(filename, col_sep: "\t")如果使用smarter_csv >= 1.4.2,还可以执行以下操作:
require 'smarter_csv'
data = SmarterCSV.process(filename, col_sep: :auto)SmarterCSV将返回一个散列数组,并且可以进行批处理
https://stackoverflow.com/questions/31614330
复制相似问题