dExtract is based on an Object-Oriented Framework to perform transformations on data on a sequential basis.
The minimal structure requires: 1. An object of the Sequential Class 2. Objects inheriting from the Base Layer Class
Data flows between layers by sending the transform output to the subsequent layer. The model can be run completely or from a specific index.
The sequential class describes a pipeline of transformations. - Layers are saved in a dictionary keyed by Layer Types and count by type. - The method summary returns the components of the model for visualization.
There are 4 main types of layers inheriting from the BaseLayer.
The slicer layer requires a data input that will be split into a series of ‘slices’ based on data sparsity/density. Row and column slices are calculated and then concatenated to fined ‘boxed areas’.
The output can be defined as a list or as search dictionary to find specific values in the resulting slices for quick identification.
The type of each row and column are defined by simple statistical thresholds. These can be customized according to user parameters.
There are 3 main data types: DATA (2), HEADING (1), EMPTY (0)
The data is then divided according to the DECISIONS matrix on
slicing.py
.
Decisions Matrix to create slices (prev_type, cur_type) as key 1. start_head (SH) - Begin counting records for a new HEADING section 2. end_head (EH) - Finish counting records for current HEADING section 3. start_data (SD) - Begin counting records for a new DATA section 4. end_data (ED) - Finish counting records for current DATA section 5. start_slice (SS) - Begin counting records for a new SLICE 6. end_slice (ES) - Finish counting records for current SLICE
SH, EH, SD, ED, SS, ES = 0, 1, 2, 3, 4, 5 DECISIONS = {(-1,0): [0,0,0,0,0,0], (-1,1): [1,0,0,0,1,0], (-1,2): [0,0,1,0,1,0], (0,0) : [0,0,0,0,0,0], (0,1) : [1,0,0,0,1,0], (0,2) : [0,0,1,0,1,0], (1,0) : [0,1,0,0,0,1], (1,1) : [0,0,0,0,0,0], (1,2) : [0,1,1,0,0,0], (2,0) : [0,0,0,1,0,1], (2,1) : [1,0,0,1,1,1], (2,2) : [0,0,0,0,0,0]}
The Cleaner layer will apply predefined transformations based on kwargs. Each transformation is applied on an individual basis.
The clean.py
helper includes all transformations and it is easily
extendible. Open the helper for a complete definition of each
transformation
The Extractor layer provides an interface to retrieve external data.
On v0.9dev1: csv, xl (Excel) and single Excel sheet are supported
Future development includes: - SAS files through the SAS7BDAT Package - Asynchronous feed-forward extraction (allow the model to run in chunks) - Web Scrapping (Both files and websites)
The Flattener layer transforms a nested dictionary of data into a single level dictionary.
It transforms all inputs into dataframes and identifies the result names by adding dictionary keys as ‘levels’ and concatenates them into a DataFrame ID.
Based on the input names dictionary or list, each dataframe is then assigned a new name matching the resulting ID.
model = Sequential() model.add(Extractor(ext_type, path, file, **kwargs)) model.add(Cleaner(clean_type = 'data', ignore_empty_cols = True, ignore_empty_rows = True, delete_by_threshold = 0.82)) model.add(Cleaner(treat_axis_as_data = 'both', header_row = 0, delete_escape_chars = True, drop_empty_columns = True)) model.add(Cleaner(compress_header = True, columns_as_row = True, treat_axis_as_data = 'columns')) model.add(Cleaner(index_as_col = True, transpose_output = True, rename_columns = {'iH':'Row_ID', 'iH_y': 'Measure', 'value':'Value'}, add_columns = {'Sheet': kwargs.get('sheet_name'), 'File_Name': file, 'Country': country, 'File_Date': date,}))