Skip to content

Import records from CSV files

conorom edited this page Jul 25, 2016 · 10 revisions

How to import records from a CSV file into fedora

  • On the same server where your Rails app is running, create a directory to put your CSV and supporting files into. You will pass this directory to the import script, and it will parse all the CSV files it finds within that directory. For supporting files, such as images or audio files, you can organize them into sub-directories if you wish, but it's not necessary.

  • Change directories to the Rails root directory

  • Keep in mind that if you are running these commands in a production environment, you will need to add RAILS_ENV=production to the beginning of each of the following commands.

  • You'll need to know the subdomain of the Press that the imported records will belong to. You can run a rake task to see all the subdomains for all Presses.

bundle exec rake press:list
  • If you want to see what options you can pass to the import script, you can run it with -h or --help to see the usage information:
bundle exec script/import --help
  • Run the import script, giving it the path to the directory where your CSV files are located, the subdomain of the Press, (and optionally, the visibility that the imported records will have).
bundle exec script/import -d /path/to/directory -p michigan -v public

Development options

There are a couple of options which can help when importing iteratively:

  1. test mode (add -t to the command) ensures that the slow process of actually creating objects never happens. This is useful for checking file names match the template and, of course, verifying the metadata itself.
  2. overwrite the monograph name by adding, e.g.:
    -m "Import test 07/25 HD"
    ... to the command. Note that the monograph row in the template is still expected at this time.