5

在 Ruby 1.9 中,我如何从 ARGF 读取 CSV?

我尝试了以下,但它什么也没打印:

require 'csv'
CSV(ARGF).read do |row|
    p row
end
4

3 回答 3

6

如果您想偷懒,可以尝试:

CSV.new(ARGF.file).each do |row|
  ...
end

来源:
http ://www.ruby-doc.org/stdlib-1.9.3/libdoc/csv/rdoc/CSV.html#label-Wrap+an+IO+Object

于 2012-10-24T19:41:43.963 回答
4

正如http://www.ruby-doc.org/stdlib-1.9.3/libdoc/csv/rdoc/CSV.html#label-Wrap+an+IO+Object中所说的使用 IO(如 ARGF)你需要创建一个新的 cvs 对象:

csv = CSV.new(io, options)

像这样的一个例子很好用:

#!/usr/bin/env ruby
#file : readCSV.rb
require "csv"
csv = CSV.new(ARGF, {:col_sep=>";", :headers=>:first_row})
csv.each do |line|
  p line.to_s
end

然后可以通过两种方式使用它:

  1. cat path/to/my.csv | ./readCSV.rb | less # for useless use of cat
  2. ./readCSV.rb < path/to/my.csv
  3. ./readCSV.rb path/to/my.csv | less
于 2016-01-22T21:13:24.897 回答
0
CSV.parse(ARGF.read) do |row|

这行得通,尽管它并不懒惰。

于 2012-10-24T19:17:37.400 回答