Ruby通过标头值解析csv

use*_*380 2 ruby csv ruby-on-rails

我正在研究一种方法来获取CSV文件(带有头文件)并使用Ruby解析它CSV.parse,但我只想保存特定的列.

CSV看起来像这样:

NAME,SUPERNET_IP,POP_NAME,ADDRESS_BLOCK_START,ADDRESS_BLOCK_END,Service,ISP Service ID,WCC,DUNSID
Retail,186.43.168.0,text1,186.43.168.0,186.43.175.255,XYZ,XYZB00090095,Enabled,227015716
Retail,186.57.80.0,text2,186.57.80.0,186.57.87.255,XYZ,XYXB00090095,Enabled,227015716
Run Code Online (Sandbox Code Playgroud)

我想要保留的唯一字段是:

POP_NAME,ADDRESS_BLOCK_START,ADDRESS_BLOCK_END,WCC
Run Code Online (Sandbox Code Playgroud)

有没有办法通过特定的标题名称解析CSV,例如:

mycsv = CSV.parse(csv_data, {:headers => true, (list of headers to keep here) })
Run Code Online (Sandbox Code Playgroud)

此示例假设csv_data是由上面的示例CSV形成的字符串.

作为权宜之计,我只是将CSV转换为阵列数组,但这并不是我所追求的.我宁愿把它保存为CSV对象.

myreturnedcsv = []
mycsv = CSV.parse(csv_data, {:headers => true, })
mycsv.each do |row|
  myreturnedcsv.push([row[2], row[3], row[4],row[7]])
end
Run Code Online (Sandbox Code Playgroud)

Pan*_*kaj 5

请尝试smarter_csvgem/parser.这能够忽略输入中的"列"(删除列)https://github.com/tilo/smarter_csv