1

如何将我的文件设置为不拉入 csv 文件中的标题?我试过这个:

CSV.foreach(email_response_file, :col_sep => "\t", :return_headers => false) do |column|
  ....
end

但是,无论我设置:return_headers为 true 还是 false,我仍然会拉入标题。我怎样才能摆脱它们?我认为我的问题是.foreach我正在使用的方法。

4

3 回答 3

4

:return_headers仅当:headersis时才有效,true但它不会按照您认为的方式工作。

如果您的 CSV 数据包含标题行,只需设置headers: true并且第一行不会作为数据行返回。相反,它被解析并允许您通过其标题访问字段(如哈希):

require 'csv'

data=<<-eos
id,name
1,foo
2,bar
eos

CSV.parse(data, headers: true) do |row|
  puts "ID: " + row["id"]
  puts "Name: " + row["name"]
  puts "1st col: " + row[0]
  puts "2nd col: " + row[1]
  puts "---"
end

输出:

ID: 1
Name: foo
1st col: 1
2nd col: foo
---
ID: 2
Name: bar
1st col: 2
2nd col: bar
---
于 2013-10-11T22:15:03.693 回答
0

我想你想要headers: false

如果失败了,您总是可以跳过第一行(是否foreach返回迭代器?)

CSV.foreach(file).each_with_index do |row, idx|


end

此外,这只是语义,但 foreach 返回一行,而不是一列

于 2013-10-11T21:49:56.713 回答
0

您还可以使用 CSV.table 将 .csv 文件读入表格。

 datatable = CSV.table("file path")

 puts datatable.headers()
于 2013-11-14T21:59:36.840 回答