# NdrImport [![Build Status](https://travis-ci.org/PublicHealthEngland/ndr_import.svg?branch=master)](https://travis-ci.org/PublicHealthEngland/ndr_import) [![Gem Version](https://badge.fury.io/rb/ndr_import.svg)](https://badge.fury.io/rb/ndr_import) This is the Public Health England (PHE) National Disease Registers (NDR) Import ETL ruby gem, providing: 1. file import handlers for *extracting* data from delimited files (csv, pipe, tab, thorn), .xls(x) spreadsheets, .doc word documents, PDF, XML and Zip files. 2. table mappers for *transforming* tabular and non-tabular data into key value pairs grouped by a common "klass". ## Installation Add this line to your application's Gemfile: ```ruby gem 'ndr_import' ``` And then execute: $ bundle Or install it yourself by cloning the project, then executing: $ gem install ndr_import.gem ## Usage Below is an example that extracts data from a PDF and transforms it into to a collection of records defined by their "klasses" and "fields": ```ruby require 'ndr_import/non_tabular/table' require 'ndr_import/file/registry' unzip_path = SafePath.new(...) source_file = SafePath.new(...).join(...) options = { 'unzip_path' => unzip_path } table = NdrImport::NonTabular::Table.new(...) # Use the Registry to enumerate over the files and their tables files = NdrImport::File::Registry.files(source_file, options) files.each do |filename| tables = NdrImport::File::Registry.tables(filename, nil, options) tables.each do |_tablename, table_content| # Use the NonTabular::Table to tabulate the table_content table.transform(table_content).each do |_klass, _fields, _index| # Your code goes here end end end ``` See test/readme_test.rb for a more complete working example. More information on the workings of the mapper are available in the [wiki](https://github.com/PublicHealthEngland/ndr_import/wiki). ## Contributing 1. Fork it ( https://github.com/PublicHealthEngland/ndr_import/fork ) 2. Create your feature branch (`git checkout -b my-new-feature`) 3. Commit your changes (`git commit -am 'Add some feature'`) 4. Push to the branch (`git push origin my-new-feature`) 5. Create a new Pull Request Please note that this project is released with a Contributor Code of Conduct. By participating in this project you agree to abide by its terms. ## Test Data All test data in this repository is fictitious. Any resemblance to real persons, living or dead, is purely coincidental although Mighty Boosh references have been used in some tests. Note: Real codes exist in the tests, postcodes for example, but bear no relation to real patient data. Please ensure that you *always* only ever commit dummy data when contributing to this project.