Outdoor air quality data
Project description
Fetch outdoor air quality data from multiple resources, the system is made of the following components:
fetching: fetches resources to create the raw material for air quality data. That material is saved to create a history and possibility to fix errors after the fact.
data extraction: extract the data from the raw material to create data feeds.
data reliability: determine which data source is the most reliable at any given time.
Architecture
The data flow from online resource to reliable data point is broken down as follow:
sources: online resources that provide the data, polled at regular interval and cached for archive purpose
feeds: extracted data from sources, feeds are saved as time series in a database
datapoint: extracted from feeds using an election algorithm to provide the most reliable data
Configuration
The default local configuration file is okqconfig.py, this can be changed using the environment variable OKQ_CONFMODULE. The okqconfig.py file should define a dict called settings, this dict can be used to overwrite any configuration option defined in the global_settings of openkongqi.conf.
Station UUID
Each station needs to be attached to a unique identier, a station identifier is of the following formats:
CC/STATION CC/CITY/STATION CC/STATE/CITY/STATION
The following fragments compose the UUID:
CC: country code - a two letter country code as defined by ISO 3166-1 alpha-2, mandatory.
STATE: state name - state name
CITY: city name - city name
STATION: stations name - station name, mandatory.
All names have to be expressed in Uppercase or lowercase or numeric latin letters.
Install
Make sure the lxml package is installed, on debian:
$ apt-get install python-lxml
Install the code:
$ pip install -U pip
$ pip install pip-tools
$ pip-sync requirements.txt
Development
Install development environment:
$ pip install -r requirements-dev.txt
Create necessary database & tables:
(openkongqi)$ python -c "import openkongqi.bin; openkongqi.bin.okq_init()"
Run celery:
(openkongqi)$ python openkongqi/bin.py worker --loglevel=debug --concurrency=1 --autoreload -B
Test
Test the package:
$ python -m unittest discover
Automatic testing in various environments:
$ tox
Versioning
Openkongqi tries to follow the PEP 440 / Semver conventions as defined by PyPA
To update the version of the package, use the following command:
$ bumpr -b -p
Packaging
Create packages:
$ python setup.py sdist bdist_wheel
Push package:
$ twine upload dist/*
$ twine upload -r pypi dist/*
Name origin
Kōngqì (空气) is the Chinese word for air/atmosphere.
License
This software is licensed under the Apache License 2.0. See the LICENSE file in the top distribution directory for the full license text.
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 openkongqi-0.2.11.tar.gz
.
File metadata
- Download URL: openkongqi-0.2.11.tar.gz
- Upload date:
- Size: 28.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/6.9.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.59.0 CPython/3.9.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | d2f493a99c74156f434393e127887e70df1fdd5616081a395289588d62b79e23 |
|
MD5 | e7d4101b5c1960220764d651dc96791f |
|
BLAKE2b-256 | 383dbb6e5f1a9363c8ea31fe24e4f2beb266f381bc64b6f3d087451b2eefd4e2 |
File details
Details for the file openkongqi-0.2.11-py2.py3-none-any.whl
.
File metadata
- Download URL: openkongqi-0.2.11-py2.py3-none-any.whl
- Upload date:
- Size: 34.1 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/6.9.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.59.0 CPython/3.9.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 7e20661706bd54ffb55d3b1dd1f1b31c1b483bfec9fff3f0bb5979709c4fa37e |
|
MD5 | f986bfc4aa2e999e2336a11d3623d6c1 |
|
BLAKE2b-256 | e44cb7a08ce90f80d4535ec8734cb2fb235965070a65860bd89303b6fb0a6b0c |