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)
| 归档时间: |
|
| 查看次数: |
3990 次 |
| 最近记录: |