remove rows in file - Ruby

前端 未结 3 627
时光取名叫无心
时光取名叫无心 2021-02-10 20:59

What is a clever way to remove rows from a CSV file in ruby where a particular value exists in a particular row?

Here\'s an example of a file:

350 lbs.,          


        
3条回答
  •  日久生厌
    2021-02-10 22:03

    You can use this to get the unique lines in an array in a csv file

    File.readlines("file.csv").uniq
    => ["350 lbs., Outrigger Footprint, 61\" x 53\", Weight, 767 lbs., 300-2080\n", "350 lbs., Outrigger Footprint, 61\" x 53\", Weight, 817 lbs., 300-2580\n", "350 lbs., Outrigger Footprint, 69\" x 61\", Weight, 867 lbs., 300-3080\n"]
    

    To write it to a new file, you can open a file in write mode, write this into the file:

    File.open("new_csv", "w+") { |file| file.puts File.readlines("csv").uniq }
    

    For comparing values, you can use split function on ",", to access each column like this:

    rows = File.readlines("csv").map(&:chomp) # equivalent to File.readlines.map { |f| f.chomp }
    mapped_columns = rows.map { |r| r.split(",").map(&:strip) }
    => [["350 lbs.", " Outrigger Footprint", " 61\" x 53\"", " Weight", " 767 lbs.", " 300-2080"], ["350 lbs.", " Outrigger Footprint", " 61\" x 53\"", " Weight", " 817 lbs.", " 300-2580"], .....]
    mapped_columns[0][5]
    => "300-2080"
    

    If you want more functionality, you are better off installing FasterCSV gem.

提交回复
热议问题