# render_csv [![Build Status](https://travis-ci.org/beerlington/render_csv.png?branch=master)](https://travis-ci.org/beerlington/render_csv) [![Gem Version](https://badge.fury.io/rb/render_csv.png)](http://badge.fury.io/rb/render_csv) [![Code Climate](https://codeclimate.com/github/beerlington/render_csv.png)](https://codeclimate.com/github/beerlington/render_csv) [![Dependency Status](https://gemnasium.com/beerlington/render_csv.png)](https://gemnasium.com/beerlington/render_csv) Rails CSV renderer for ActiveRecord collections ## Rails & Ruby Versions Supported *Rails:* 3.0.x - 4.0.x *Ruby:* 1.9.2, 1.9.3 and 2.0.0 ## Installation The gem is hosted at [rubygems.org](https://rubygems.org/gems/render_csv) ## What is it? The CSV renderer allows you to render any collection as CSV data. ```ruby class LocationsController < ApplicationController def index @locations = Location.all respond_to do |format| format.csv { render csv: @locations } end end end ``` Will render a CSV file similar to:
nameaddresscitystatezipcreated_atupdated_at
Pete's House555 House LnBurlingtonVT054012011-07-26 03:12:44 UTC2011-07-26 03:12:44 UTC
Sebastians's House123 Pup StBurlingtonVT054012011-07-26 03:30:44 UTC2011-07-26 03:30:44 UTC
Someone Else999 Herp DerpBurlingtonVT054012011-07-26 03:30:44 UTC2011-07-26 03:30:44 UTC
## Usage Options There are a few options you can use to customize which columns are included in the CSV file ### Exclude columns ```ruby respond_to do |format| format.csv { render csv: @locations, except: [:id] } end ``` ### Limit columns ```ruby respond_to do |format| format.csv { render csv: @locations, only: [:address, :zip] } end ``` ### Add methods as columns ```ruby respond_to do |format| format.csv { render csv: @locations, add_methods: [:method1, :method2] } end ``` ### Add methods as columns and exclude columns ```ruby respond_to do |format| format.csv { render csv: @locations, except: [:id], add_methods: [:method1, :method2] } end ``` ## Copyright Copyright © 2011-2014 Peter Brown. See LICENSE.txt for further details.