Rails Importer (XML, XLS, CSV)
Add it to your Gemfile:
gem 'rails-importer'
Run the following command to install it:
$ bundle install
$ rails generate rails_importer:install
You can generate importers app/importers/example_importer.rb
$ rails generate rails_importer:importer example
Generator will make a file with content like:
class ExampleImporter < RailsImporter::Base
importer do
fields :name, :email, :age
#or fields({:name => "Name", :email => "E-mail", :age => "Idade"})
each_record do |record, params|
MyModel.find_or_create_by(name: record[:name], email: record[:email], age: record[:age])
return record # or return wherever
end
end
# importer :simple do
# csv_params col_sep: ';'
# xml_structure :root, :row
# fields :name, :email, :age
# each_record do |record, params|
# ...
# end
# end
end
You can call import
from Importers objects:
file param must be an object that responds to .path
method
file = params[:import][:file]
records = ExampleImporter.import(file)
Or with context:
file = params[:import][:file]
records = ExampleImporter.import(file, context: :simple)
Overwrite default fields (called in the block importer do
):
file = params[:import][:file]
records = ExampleImporter.import(file, fields: [:name, :email, :age])
With extra params:
file = params[:import][:file]
records = ExampleImporter.import(file, {user: '[email protected]'})
Then inside each record you can get params:
class ExampleImporter < RailsImporter::Base
importer do
# ...
each_record do |record, params|
# ...
params[:user]
# ...
end
# ...
end
end
With full options:
file = params[:import][:file]
records = ExampleImporter.import(file,
context: :simple,
fields: [:name, :email, :age],
{user: '[email protected]', account: '1'})
To return imported values, you need to return values inside of each_record
:
class ExampleImporter < RailsImporter::Base
importer do
# ...
each_record do |record, params|
# ...
u = Model.new(record)
u.created_by = params[:user]
ok = !!u.save
return {record: u, success: ok}
end
# ...
end
end
records = ExampleImporter.import(file, {user: '[email protected]'})
# [{record: ..., success: true}, {record: ..., success: false}]