csv_converter Build Status

csv_converter is a library for facilitating the grouping and transformation of tabulated data contained in files such as csv or spreadsheets files. This is not a library for parsing files. There are already plenty of libraries out there for reading and parsing files in different formats.

Instead, this library focuses on the conversion of the data provided in the files. Often times, it is required to cast the text data into a ruby object, perform validations on that data, and map it to the corresponding db tables/models and columns/attributes. This library aims to simplify that process.

For example, given the following csv content:

First Name,Last Name,Make,Model,Year,Color,Purchase Date
John,Smith,Ford,Mustang,2000,Black,25/01/99
Julian,Moore,Toyota,Yaris,2005,Red,13/04/05
Joe,Black,Volvo,V40,2015,Gold,03/02/16
First Name Last Name Make Model Year Color Purchase Date
John Smith Ford Mustang 2000 Black 25/01/99
Julian Moore Toyota Yaris 2005 Red 13/04/05
Joe Black Volvo V40 2015 Gold 03/02/16

you might want something like this:

[
  {
    "owner" => {
      "first_name" => "John",
      "last_name" => "Smith"
    },
    "vehicle" => {
      "make" => "Ford",
      "model" => "Mustang",
      "year" => 2000,
      "color" => "Black",
      "purchase_date" => #<Date: 1999-01-25 ((2451204j,0s,0n),+0s,2299161j)>
    }
  },
  {
    "owner" => {
      "first_name" => "Julian",
      "last_name" => "Moore"
    },
    "vehicle" => {
      "make" => "Toyota",
      "model" => "Yaris",
      "year" => 2005,
      "color" => "Red",
      "purchase_date" => #<Date: 2005-04-15 ((2453476j,0s,0n),+0s,2299161j)>
    }
  },
  {
    "owner" => {
      "first_name" => "Joe",
      "last_name" => "Black"
    },
    "vehicle" => {
      "make" => "Volvo",
      "model" => "V40",
      "year" => 2015,
      "color" => "Gold",
      "purchase_date" => #<Date: 2016-03-02 ((2457450j,0s,0n),+0s,2299161j)>
    }
  }
]

In this example, each column from the csv has been grouped according to the configuration provided. Also, the data for each column has been converted to the expected data type.

This is performed by csv_converter based on the configuration provided in a .yml file (or a ruby hash) that lookes like this:

owner:
  first_name:
    header: First Name
  last_name:
    header: Last Name
vehicle:
  make:
    header: Make
  model:
    header: Model
  year:
    header: Year
    converters:
      integer:
  color:
    header: Color
  purchase_date:
    header: Purchase Date
    converters:
      date:
        date_format: "%m/%d/%y"

Usage

csv_converter supports more advanced data conversions, processing data based on column position instead of headers and nested records within a column.

Please refer to the wiki page for further instructions and more advanced examples.

Installation

Add this line to your application's Gemfile:

gem 'csv_converter'

And then execute:

$ bundle

Or install it yourself as:

$ gem install csv_converter

Documentation

You can view the csv_converter documentation in RDoc format here:

https://rubydoc.info/github/francisco-rojas/csv_converter/master

You can also view the wiki here:

https://github.com/francisco-rojas/csv_converter/wiki

Finally, you can check the Readme and source code here:

https://github.com/francisco-rojas/csv_converter

Development

Currently, the library is stable. I believe it supports the most common use cases so most likely the code won't be updated very frequently. However, if you have any feature requests or find a bug feel free to open a github issue and I will reply as soon as I can.

  • for feature requests please use the enhancement label.
  • for bugs please use the bugs label.

Contributing

Bug reports and pull requests are welcome on GitHub at https://github.com/francisco-rojas/csv_converter

License

MIT License. Copyright 2019 Francisco Rojas. https://github.com/francisco-rojas