Skip to main content

Python library to obtain climate and air quality data from monitoring stations in Chile

Project description

atmchile

CI PyPI Python codecov Open In Colab

Python library to download air quality and climate data from two Chilean government monitoring networks: SINCA (Sistema de Información Nacional de Calidad del Aire), operated by the Ministry of Environment of Chile (MMA — Ministerio del Medio Ambiente), and DMC (Dirección Meteorológica de Chile). Both modules return tidy pandas DataFrames with download-lineage columns, and support synchronous and asynchronous bulk downloads.

Installation

pip install atmchile

Quick Start

from datetime import datetime
from atmchile import ChileAirQuality

caq = ChileAirQuality()
df = caq.get_data(
    stations="RM/D14",
    parameters=["PM10", "PM25"],
    start=datetime(2020, 1, 1),
    end=datetime(2020, 1, 31),
)
print(df.head())

Available Parameters

ChileAirQuality (SINCA)

Parameter Description Unit
PM10 Particulate matter ≤ 10 µm (hourly average) µg/m³N
PM25 Particulate matter ≤ 2.5 µm (hourly average) µg/m³N
SO2 Sulfur dioxide µg/m³N
NOX Nitrogen oxides (NO + NO₂) ppb
NO2 Nitrogen dioxide ppb
NO Nitric oxide ppb
O3 Tropospheric ozone ppb
CO Carbon monoxide ppb
temp Air temperature °C
RH Relative humidity %
ws Wind speed m/s
wd Wind direction (meteorological convention) °

Units: µg/m³N = micrograms per normal cubic metre (0 °C, 1 atm); ppb = parts per billion by volume.

ChileClimateData (DMC)

Parameter Description Output column(s) Unit
Temperatura Air temperature Ts °C
PuntoRocio Dew point temperature Td °C
Humedad Relative humidity HR %
Viento Wind dd (direction), ff (speed), VRB (variability flag) ° / m/s / —
PresionQFE Station-level pressure (QFE) QFE hPa
PresionQFF Sea-level pressure (QFF) QFF hPa

Usage

ChileAirQuality

from datetime import datetime
from atmchile import ChileAirQuality

caq = ChileAirQuality()

data = caq.get_data(
    stations="El Bosque",
    parameters=["PM10", "PM25"],
    start=datetime(2020, 1, 1),
    end=datetime(2020, 1, 2),
)
print(data)
import asyncio
from datetime import datetime
from atmchile import ChileAirQuality

async def main():
    caq = ChileAirQuality(max_concurrent_downloads=5)

    data = await caq.get_data_async(
        stations=["RM", "II"],
        parameters=["PM10", "PM25"],
        start=datetime(2020, 1, 1),
        end=datetime(2021, 12, 31),
        region=True,
    )
    print(data)

asyncio.run(main())

ChileClimateData

from datetime import datetime
from atmchile import ChileClimateData

ccd = ChileClimateData()

data = ccd.get_data(
    stations="180005",
    parameters=["Temperatura", "Humedad"],
    start=datetime(2020, 1, 1, 0, 0, 0),
    end=datetime(2020, 12, 31, 23, 0, 0),
)
print(data)
import asyncio
from datetime import datetime
from atmchile import ChileClimateData

async def main():
    ccd = ChileClimateData(max_concurrent_downloads=5)

    data = await ccd.get_data_async(
        stations=["RM", "II"],
        parameters=["Temperatura", "PresionQFE"],
        start=datetime(2020, 1, 1, 0, 0, 0),
        end=datetime(2021, 12, 31, 23, 0, 0),
        region=True,
    )
    print(data)

asyncio.run(main())

Output columns & data lineage

Every DataFrame includes dl.* lineage columns alongside measurement values, recording the download and curation status of each individual data point. For the full column schema, dl.* status values, curation rules, and validation tiers for both classes, see docs/output-columns.md.

Data Sources

SINCA — air quality

SINCA (Sistema de Información Nacional de Calidad del Aire) is Chile's national air quality monitoring network, operated by the Ministry of Environment (MMA). It covers 120+ stations distributed across the country's administrative regions, measuring hourly concentrations of criteria pollutants and meteorological variables.

DMC — climate

DMC (Dirección Meteorológica de Chile) is Chile's national weather service, operated by the Dirección General de Aeronáutica Civil (DGAC). It provides synoptic climate observations (temperature, dew point, humidity, wind, surface and sea-level pressure) from stations nationwide.

Development

Run tests

# Run all tests
uv run pytest

# Run with more verbosity
uv run pytest -v

# Run tests with coverage (minimum threshold 90%)
uv run test-cov

Refresh station metadata

uv run refresh-stations

Fetches the current station list from the SINCA listadomapa2k19 endpoint and overwrites src/atmchile/data/sinca_stations.csv. Run this whenever SINCA adds or removes stations. The command prints a summary of stations written and a UTC timestamp.

If any station has an unrecognised region string, a WARNING line is printed and the station is written with region='UNKNOWN' so data loss is visible rather than silent. In that case, update REGION_MAP in src/atmchile/scripts.py before committing the refreshed CSV.

Linting and formatting

uv run ruff check . --fix
uv run ruff format .

Update dependencies

uv lock --upgrade && uv sync --all-extras

SINCA internals

SINCA has no publicly documented API. This library accesses data through reverse-engineered endpoints of the underlying Airviro platform. For details on backend architecture, station metadata discovery, parameter code mapping, URL construction, and response format, see docs/sinca-internals.md.

Attribution & AI Disclosure

This library is a Python port of the AtmChile R package by Francisco Menares et al., developed at the Department of Chemistry, Faculty of Sciences, Universidad de Chile. The original work was funded by ANID/FONDECYT Grant No. 1200674 (Fondo Nacional de Desarrollo Científico y Tecnológico, Chile's national research funding agency).

The original package is described in:

Menares et al. (2022). The AtmChile Open-Source Interactive Application for Exploring Air Quality and Meteorological Data in Chile. Atmosphere, 13(9), 1364.

The initial R-to-Python port was generated with the assistance of Claude (Anthropic) AI. Subsequent architecture decisions, testing, and incremental improvements were made by the author.

License

This project is licensed under the GNU General Public License v3.0, inherited from the original AtmChile R package.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

atmchile-0.2.3.tar.gz (214.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

atmchile-0.2.3-py3-none-any.whl (41.8 kB view details)

Uploaded Python 3

File details

Details for the file atmchile-0.2.3.tar.gz.

File metadata

  • Download URL: atmchile-0.2.3.tar.gz
  • Upload date:
  • Size: 214.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for atmchile-0.2.3.tar.gz
Algorithm Hash digest
SHA256 19738c7a1b9f1e19fba1f5af338f4dbb797ff43350c81a44c224ca9111c5a477
MD5 92b9b8645c18a9ecfd38b073c1ef9796
BLAKE2b-256 d39a6e6e41882f1c8dd5e7b68d6993145864ecf7c420d8d14c44ae40e838f050

See more details on using hashes here.

Provenance

The following attestation bundles were made for atmchile-0.2.3.tar.gz:

Publisher: publish.yml on maigonzalezh/py-atmchile

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file atmchile-0.2.3-py3-none-any.whl.

File metadata

  • Download URL: atmchile-0.2.3-py3-none-any.whl
  • Upload date:
  • Size: 41.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for atmchile-0.2.3-py3-none-any.whl
Algorithm Hash digest
SHA256 ca5ecfcf1b7cd88eb3b060f6fde4796b05f021e6f1c839fa5132867a5f5d1edd
MD5 0ebfba386e7561ae56cdb96b9bc670fb
BLAKE2b-256 50acf8bf84dfb0939645498f0f6e086828d5f4336afd50380890dee7ea4b4391

See more details on using hashes here.

Provenance

The following attestation bundles were made for atmchile-0.2.3-py3-none-any.whl:

Publisher: publish.yml on maigonzalezh/py-atmchile

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page