如果第一行后面跟一个空行,则Ruby CSV找不到文件头

时间:2014-02-28 17:49:49

标签: ruby csv

我遇到了一个奇怪的问题,我的脚本无法在某些CSV文件上运行。问题如下,我需要访问列名(文件头)以正确处理文件。我一直在使用以下(测试)代码列出标题:

CSV file = CSV.read(argument, :headers => true)
if file.headers() == nil
    puts "According to the doc : Headers will not be used"
elsif file.headers() == true
    puts "According to the doc : Headers will be used, but not read yet"
else
    puts "Headers were read, this is an array : #{file.headers.to_s}"
end

现在,应用于第一个csv:

key,fr
edit,Éditer
close,Fermer

我明白了:

Headers were read, this is an array : ["key", "fr"]

但是,如果我知道在标题和内容本身之间添加一个空行,就像这样:

key,fr

edit,Éditer
close,Fermer

它不再起作用了:

Headers were read, this is an array : []

这令我感到困惑。这是预期的行为吗?我能做些什么吗?我一直在阅读ruby CSV doc,但找不到任何东西。 可能是一些我不知道的csv文件规格? 测试ruby 1.9.3和2.1.1

1 个答案:

答案 0 :(得分:3)

在您阅读 CSV 文件时添加选项:skip_blanks => true

file = CSV.read(path, :headers => true,:skip_blanks => true)

此选项:skip_blanks => true将跳过所有此类空行,如果您有任何礼物,您将获得正常输出。

这是我的尝试:

require 'csv'

content = <<_
key,fr

edit,Éditer
close,Fermer
_

File.write('test',content)

file = CSV.read('test', :headers => true,:skip_blanks => true)
if file.headers() == nil
    puts "According to the doc : Headers will not be used"
elsif file.headers() == true
    puts "According to the doc : Headers will be used, but not read yet"
else
    puts "Headers were read, this is an array : #{file.headers.to_s}"
end
# >> Headers were read, this is an array : ["key", "fr"]

正如你所说的那样正常工作,我也同意你的意见,低于一个:

require 'csv'

content = <<_
key,fr
edit,Éditer
close,Fermer
_

File.write('test',content)

file = CSV.read('test', :headers => true)
file.headers # => ["key", "fr"]
file.to_a # => [["key", "fr"], ["edit", "Éditer"], ["close", "Fermer"]]

当您设置:headers => true,CSV数据的第一行时,您将获得标题。考虑到这个定义,上面说得很好。但下面的一个矛盾:

require 'csv'

File.write('test',content)

file = CSV.read('test', :headers => true)
file.headers # => ["key", "fr"]
file.to_a # => [["key", "fr"], ["edit", "Éditer"], ["close", "Fermer"]]

content = <<_
key,fr

edit,Éditer
close,Fermer
_

File.write('test1',content)

file = CSV.read('test1', :headers => true)
file.headers # => []  # <~~~~~~~~~~~ Is this a bug ?
file.to_a # => [[], [], ["edit", "Éditer"], ["close", "Fermer"]]

file.headers给出一个空数组[],您可以在{{1}输出的 0 th 索引中看到}也是一个空数组(file.to_a)。但它似乎是一个错误。因此我提出了issue