Skip to content

myslak71/report-processer

Repository files navigation

CSV Report Processer

Build Status Coverage Status image

Description

Package reads data from CSV file, with rows formatted as follows:

mm/dd/yyy,state_name,number_of_impressions,CTR%

and converts it according to the table:

INPUT FORMAT OUTPUT FORMAT
date yyyy-mm-dd
state_name three letter country code or 'XXX' if state_name does not exist in ISO 3166-2
number_of_impressions casted to int
CTR% number of clicks based on CTR% and number of impressions

In addition rows are aggregated and sorted lexicographically by date followed by country code.

Example

INPUT OUTPUT
01/21/2019,Mandiana,883,0.38% 2019-01-21,AFG,919,6
01/21/2019,Lola,76,0.78% 2019-01-21,GIN,959,4
01/21/2019,Fāryāb,919,0.67% 2019-01-22,CZE,139,1
01/22/2019,Lola,201,0.82% 2019-01-22,GIN,1251,12
01/22/2019,Beroun,139,0.61% 2019-01-23,GIN,593,2
01/22/2019,Mandiana,1050,0.93% 2019-01-23,XXX,777,2
01/23/2019, 323 ,777,0.22% 2019-01-24,CZE,620,1
01/23/2019,Gaoual,72,0.7% 2019-01-24,XXX,1668,12
01/23/2019,Lola,521,0.19%
01/24/2019,Beroun,620,0.1%
01/24/2019,Unknown,586,0.86%
01/24/2019, 234 ,1082,0.68%

If ERROR_PATH is specified, corrupted rows are excluded from the OUTPUT_PATH file and saved as CSV file.

If ERROR_PATH is not specified, corrupted rows are not considered critical and are included in the OUTPUT_PATH file with appropriate error message.

All program logs are stored in report_processer.log file, which is created in the program run directory.

Installation

Installing the package for CLI purposes

pip install git+https://github.com/myslak71/report_processer.git

Usage

$ csv-report-processer [-h] -i INPUT_PATH -o OUTPUT_PATH [-e ERROR_PATH]
OPTION DESCRIPTION
-i, --input REQUIRED Path to input CSV file
-o, --output REQUIRED Path to output CSV file
-e, --error OPTIONAL Path to output CSV file with corrupted rows
-h, --help OPTIONAL Help

If installing the package is not desired, example.py from example dir may be run.

About

CSV file processer.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages