Skip to main content

A Python wrapper for the APIs of MeasureSpace.io

Project description

Measure Space API Python Package

A Python package for accessing weather, climate, air quality, agriculture, pollen, and geocoding APIs provided by MeasureSpace.io.

Features

Global Hourly Weather Forecast

  • 5-day forecast at hourly frequency and global scale
  • over 20 common weather variables with timezone and weather icons
  • available at local and UTC time
  • imperial and metric units
  • support agriculture, logistics, IoT and many other general weather applications

Global Daily Weather Forecast

  • 15-day forecast at daily frequency and global scale
  • over 30 common weather variables with timezone, sunrise, sunset and weather icons
  • available at local and UTC time
  • daytime and nighttime aggregations
  • imperial and metric units
  • support agriculture, logistics, IoT and many other general weather applications

Global Climate Forecast

  • 10-month forecast at daily frequency and global scale
  • 11 common variables
  • imperial and metric units
  • support agriculture and many other general climate applications

Global Air Quality Forecast

  • 5-day air quality forecast at hourly and daily frequency and global scale
  • 7 common air pollutants including Air Quality Index
  • help people plan outdoor activities and make health product marketing more efficient

Global City Geocoding

  • dedicated to city geocoding and reverse geocoding
  • autocomplete for more than 200,000 cities from 245 countries
  • get matched cities based on user inputs
  • convert city names to corresponding latitude and longitude info
  • find nearest city based on latitude and longitude
  • live demo through our weather dashboard search city feature

Agriculture

  • growing degree days forecast
  • growth stage forecast
  • heat stress forecast
  • frost stress forecast
  • data from past year to next 9 months
  • imperial and metric units
  • support major crops like corn, soybean, wheat, rice and many others

Global Pollen Forecast

  • 10-day pollen forecast at daily frequency and global scale
  • 3 common pollen types
  • help people plan outdoor activities and make health product marketing more efficient

Installation

Clone the repository and install dependencies:

pip install -e .

Or install from PyPI:

pip install measure-space-api

Usage

Get Weather, Climate, Air Quality, Agriculture and Pollen Variables

Import the package and call the functions:

from measure_space_api import (
    get_hourly_weather, get_daily_weather, get_daily_climate,
    get_hourly_air_quality, get_daily_air_quality,
    get_lat_lon_from_city, get_city_from_lat_lon,
    get_daily_pollen, get_growing_degree_days,
    get_heat_stress_days, get_frost_stress_days,
    get_growth_stage,
)

# Example: Get hourly weather by coordinates
api_key = "YOUR_API_KEY"
params = {
    # Variable names and meaning can be found at https://measurespace.io/documentation#global-hourly-weather-forecast-variables
    "variables": "tp,t2m",
    "unit": "metric"
}
df = get_hourly_weather(api_key, latitude=40.2, longitude=110.2, params=params, return_json=False)
print(df.head())

# Example: Get hourly weather by city name
geocoding_api_key = "YOUR_GEOCODING_API_KEY"
df = get_hourly_weather(api_key, geocoding_api_key, location_name="Beijing", params=params, return_json=False)
print(df.head())

# Example: get metadata (variable description, unit)
get_metadata('tp', unit='metric')

# Example: Get daily pollen forecast by coordinates
pollen_api_key = "YOUR_POLLEN_API_KEY"
data = get_daily_pollen(pollen_api_key, latitude=40.2, longitude=-74.0)
print(data)

# Example: Get daily pollen forecast by city name
data = get_daily_pollen(pollen_api_key, geocoding_api_key=geocoding_api_key, location_name="New York")
print(data)

# Example: Get growing degree days
ag_api_key = "YOUR_AGRICULTURE_API_KEY"
params = {
    'start_date': '2025-01-01',
    'end_date': '2025-06-01',
    'base_temperature': 50,
    'unit': 'F',
}
data = get_growing_degree_days(ag_api_key, latitude=40.2, longitude=-89.0, params=params)
print(data)

# Example: Get crop growth stage
params = {
    'start_date': '2025-04-01',
    'end_date': '2025-09-01',
    'crop_name': 'corn',
    'unit': 'F',
}
data = get_growth_stage(ag_api_key, latitude=40.2, longitude=-89.0, params=params)
print(data)

# Example: Get heat stress days
params = {
    'start_date': '2025-06-01',
    'end_date': '2025-08-31',
    'crop_name': 'corn',
    'heat_stress_threshold': 95,
}
data = get_heat_stress_days(ag_api_key, latitude=40.2, longitude=-89.0, params=params)
print(data)

# Example: Get frost stress days
params = {
    'start_date': '2025-10-01',
    'end_date': '2025-12-31',
    'frost_stress_threshold': 32,
}
data = get_frost_stress_days(ag_api_key, latitude=40.2, longitude=-89.0, params=params)
print(data)

Get City Coordinates

from measure_space_api.main import get_lat_lon_from_city
lat, lon = get_lat_lon_from_city(geocoding_api_key, "Shanghai")
print(lat, lon)

Use Environment Variables

You may use a .env file to store your API keys and load them with python-dotenv.

HOURLY_WEATHER_API_KEY=your_hourly_weather_key
DAILY_WEATHER_API_KEY=your_daily_weather_key
DAILY_CLIMATE_API_KEY=your_daily_climate_key
AIR_QUALITY_API_KEY=your_air_quality_key
GEOCODING_API_KEY=your_geocoding_key
POLLEN_API_KEY=your_pollen_key
GROWING_DEGREE_DAYS_API_KEY=your_growing_degree_days_key
HEAT_STRESS_DAYS_API_KEY=your_heat_stress_days_key
FROST_STRESS_DAYS_API_KEY=your_frost_stress_days_key
GROWTH_STAGE_API_KEY=your_growth_stage_key

Call API using API keys from .env file.

from measure_space_api import (
    get_hourly_weather, get_daily_weather, get_daily_climate,
    get_hourly_air_quality, get_daily_air_quality,
    get_lat_lon_from_city, get_city_from_lat_lon,
    get_daily_pollen, get_growing_degree_days,
    get_heat_stress_days, get_frost_stress_days,
    get_growth_stage,
)
from dotenv import load_dotenv
import os

# Load environment variables from .env file
load_dotenv()
# Example: Get hourly weather by coordinates
params = {
    # Variable names and meaning can be found at https://measurespace.io/documentation#global-hourly-weather-forecast-variables
    "variables": "tp,t2m",
    "unit": "metric"
}
df = get_hourly_weather(HOURLY_WEATHER_API_KEY, latitude=40.2, longitude=110.2, params=params, return_json=False)
print(df.head())

API Functions

Weather and Climate

  • get_hourly_weather(api_key, geocoding_api_key=None, location_name=None, latitude=None, longitude=None, params={'variables': 'tp, t2m', 'unit': 'metric'}, return_json=True)
  • get_daily_weather(api_key, geocoding_api_key=None, location_name=None, latitude=None, longitude=None, params={'variables': 'tp, minT, maxT', 'unit': 'metric'}, return_json=True)
  • get_daily_climate(api_key, geocoding_api_key=None, location_name=None, latitude=None, longitude=None, params={'variables': 'tp, tmin, tmax', 'unit': 'metric'}, return_json=True)

Air Quality

  • get_hourly_air_quality(api_key, geocoding_api_key=None, location_name=None, latitude=None, longitude=None, params={'variables': 'AQI, DP'}, return_json=True)
  • get_daily_air_quality(api_key, geocoding_api_key=None, location_name=None, latitude=None, longitude=None, params={'variables': 'AQI'}, return_json=True)

Pollen

  • get_daily_pollen(api_key, geocoding_api_key=None, location_name=None, latitude=None, longitude=None, params={}, return_json=True)

Agriculture

  • get_growing_degree_days(api_key, latitude, longitude, params={'start_date': None, 'end_date': None, 'base_temperature': 50, 'lower_cutoff': None, 'upper_cutoff': None, 'unit': 'F'}, return_json=True)
  • get_growth_stage(api_key, latitude, longitude, params={'start_date': None, 'end_date': None, 'crop_name': None, 'unit': 'F'}, return_json=True)
  • get_heat_stress_days(api_key, latitude, longitude, params={'start_date': None, 'end_date': None, 'crop_name': None, 'heat_stress_threshold': None}, return_json=True)
  • get_frost_stress_days(api_key, latitude, longitude, params={'start_date': None, 'end_date': None, 'frost_stress_threshold': None}, return_json=True)

Geocoding

  • get_lat_lon_from_city(api_key, location_name)
  • get_city_from_lat_lon(api_key, latitude, longitude)

Parameters

  • api_key: Your API key for the weather/climate/air quality service
  • geocoding_api_key: (Optional) API key for geocoding service
  • location_name: (Optional) City name (e.g., "New York", "Beijing, China")
  • latitude, longitude: (Optional) Coordinates
  • params: (Optional) Dictionary of additional API parameters (e.g., variables, units, local_flag)
  • return_json: If True, returns JSON; if False, returns a pandas DataFrame

API Documentation

Publish to PyPI

  • uv build
  • uv publish --token <your-pypi-token>

License

Apache License

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

measure_space_api-0.1.4.tar.gz (16.8 kB view details)

Uploaded Source

Built Distribution

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

measure_space_api-0.1.4-py3-none-any.whl (12.9 kB view details)

Uploaded Python 3

File details

Details for the file measure_space_api-0.1.4.tar.gz.

File metadata

  • Download URL: measure_space_api-0.1.4.tar.gz
  • Upload date:
  • Size: 16.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.6.10

File hashes

Hashes for measure_space_api-0.1.4.tar.gz
Algorithm Hash digest
SHA256 84b88831d263f163ada9a776c300e8244cc3939c5391967954d4c591dd4fa3a9
MD5 e93404301874e3d4a9d37a880a498dee
BLAKE2b-256 1aa3640f8fb08c37df60f27240a5210736ce2672e23fec428341559f4767cdf8

See more details on using hashes here.

File details

Details for the file measure_space_api-0.1.4-py3-none-any.whl.

File metadata

File hashes

Hashes for measure_space_api-0.1.4-py3-none-any.whl
Algorithm Hash digest
SHA256 c13def1b4be267c603afcfed2fb7201777d1067a4fcf0ca0b3557cca2453271d
MD5 3da758250ff59c61a29e4c4312671118
BLAKE2b-256 a300052d6971a1735b0c9570ae4e8cb80db1c37b8dc07ba5c9d6919077918646

See more details on using hashes here.

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