Python package to scrape time series data from excel files.
Project description
A python package to scrape time series from any excel file and return them turned into pandas data frames.
Installation
If you want to install in developer mode, clone the repository and follow these instructions:
If you are using Anaconda as your python distribution
conda create -n xlseries python=2 Create new environment
cd project_directory
source activate xlseries Activate the environment
pip install -e . Install the package in developer mode
pip install -r requirements.txt Install dependencies
deactivate Deactivate when you are done
If you are using a standard python installation
cd project_directory
virtualenv venv Create new environment
source venv/bin/activate Activate the environment
pip install -r requirements.txt Install dependencies
deactivate Deactivate when you are done
If you just want to use it:
pip install xlseries in your environment, instead of cloning and pip installing in developer mode.
Quick start
from xlseries import XlSeries
xl = XlSeries("path_to_excel_file" or openpyxl.Workbook instance)
dfs = xl.get_data_frames("path_to_json_parameters" or parameters_dictionary)
With the test case number 1:
from xlseries import XlSeries
from xlseries.utils.path_finders import get_orig_cases_path, get_param_cases_path
# this will only work if you clone the repo with all the test files
path_to_excel_file = get_orig_cases_path(1)
path_to_json_parameters = get_param_cases_path(1)
xl = XlSeries(path_to_excel_file)
dfs = series.get_data_frames(path_to_json_parameters)
or passing only the critical parameters as a dictionary:
parameters_dictionary = {
"headers_coord": ["B1","C1"],
"data_starts": 2,
"frequency": "M",
"time_header_coord": "A1"
}
dfs = xl.get_data_frames(parameters_dictionary)
you can specify what worksheet you want to scrape (otherwise the first one will be used):
dfs = xl.get_data_frames(parameters_dictionary, ws_name="my_worksheet")
you can ask an XlSeries object for a template dictionary of the critical parameters you need to fill:
>>> params = xl.critical_params_template()
>>> params
{'data_starts': 2,
'frequency': 'M',
'headers_coord': ['B1', 'C1', 'E1-G1'],
'time_header_coord': 'A1'}
>>> params["headers_coord"] = ["B1","C1"]
>>> dfs = xl.get_data_frames(params, ws_name="my_worksheet")
if this doesn’t work and you want to see exactly where the scraping is failing, you may want to fill out all the parameters and try again to see where the exception is raised:
>>> params = xl.complete_params_template()
>>> params
{'alignment': u'vertical',
'blank_rows': False,
'continuity': True,
'data_ends': None,
'data_starts': 2,
'frequency': 'M',
'headers_coord': ['B1', 'C1', 'E1-G1'],
'missing_value': [None, '-', '...', '.', ''],
'missings': False,
'series_names': None,
'time_alignment': 0,
'time_composed': False,
'time_header_coord': 'A1',
'time_multicolumn': False}
>>> params["headers_coord"] = ["B1","C1"]
>>> params["data_ends"] = 256
>>> params["missings"] = True
>>> dfs = xl.get_data_frames(params, ws_name="my_worksheet")
Excel file: Up to this development point the excel file should not be more complicated than the 7 test cases:
Parameters: Together with the excel file, some parameters about the series must be provided. These could be passed to get_data_frames() as a path to a JSON file or as a python dictionary. xlseries use about 14 parameters to characterize the time series of a spreadsheet, but only 4 of them are critical most of the time: the rest can be guessed by the package. The only difference between specifying more or less parameters than the 4 critical is the total time that xlseries will need to complete the task (more parameters, less time). Go to the parameters section for a more detailed explanation about how to use them, and when you need to specify more than the basic 4 (headers_coord, data_starts, frequency and time_header_coord).
Take a look to this ipython notebook template to get started!.
If you want to dig inside the test cases and get an idea of how far is going xlseries at the moment, check out this ipython notebook with the 7 test cases.
For more details go to the official repository on github: https://github.com/abenassi/xlseries
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file xlseries-0.2.6.tar.gz
.
File metadata
- Download URL: xlseries-0.2.6.tar.gz
- Upload date:
- Size: 13.9 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.0 CPython/3.9.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | ab43b63c1dfbc052705dd2f40997fc9cf138346878cbb43915f24ee40cbfcf8b |
|
MD5 | 5ebe8247ef41c7b68f1aa322a2e03cf8 |
|
BLAKE2b-256 | 3b7d065419d8809de24c531357becd89a2e236a6c6650f610a335c51bce414f2 |
File details
Details for the file xlseries-0.2.6-py3-none-any.whl
.
File metadata
- Download URL: xlseries-0.2.6-py3-none-any.whl
- Upload date:
- Size: 13.9 MB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.0 CPython/3.9.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | fcc4c53366995102e9902e094485a440e81683827298d12e08d6721350974e9e |
|
MD5 | 9baa677e7737af35cf786975ef654b2d |
|
BLAKE2b-256 | 40bb042bb2877f255a855f5ee8fdd007a49d1048408dc22f1239bb68a36fc843 |