Socket
Socket
Sign inDemoInstall

pymeteoclimatic

Package Overview
Dependencies
2
Maintainers
1
Alerts
File Explorer

Install Socket

Detect and block malicious and high-risk dependencies

Install

    pymeteoclimatic

A Python wrapper around the Meteoclimatic service


Maintainers
1

Readme

PyMeteoclimatic

A Python wrapper around the Meteoclimatic service.

Coverage Status Build & Test Publish to Pypi

PyMeteoclimatic is a client Python wrapper library for Meteoclimatic. Meteoclimatic is a large network of non-professional automatic real-time weather stations and an important directory of weather resources. The geographical scope of Meteoclimatic comprises the Iberian Peninsula, the two Spanish archipelagos (the Balearic Islands and the Canary Islands), southern France and Africa near the Strait of Gibraltar.

PyMeteoclimatic relies on the Meteoclimatic RSS feed. More specifically, PyMeteoclimatic leverages the coded, normalized data blocks included as HTML comments in the feeds between the [[<BEGIN:identificador:DATA>]] and [[<END:identificador:DATA>]] tags to obtain station weather information.

What data can I get?

With PyMeteoclimatic you can obtain weather information directly from Meteoclimatic stations identified by their code. You can find out the station code from the station profile page in the Meteoclimatic site.

When obtaining the weather information from a station, you will get a meteoclimatic.Observation object, which represents the weather which is currently being observed from a certain station and contains the following fields.

FieldTypeDescription
reception_timedatetime.datetimeTimestamp telling when the weather obervation has been received from the station
stationmeteoclimatic.StationThe Station relative to this observation
weathermeteoclimatic.WeatherThe Weather relative to this observation

A meteoclimatic.Station object contains the following data.

FieldTypeDescription
namestrName of the station
codestrMeteoclimatic code of the station (e.g. "ESCAT4300000043206B")
urlstrURL of the Meteoclimatic station page

A meteoclimatic.Weather object contains the following data. Note that not all stations have the same physical sensors and capabilities (e.g. pluviometer, barometer, ...), therefore, some of these values may be None for some stations. Check the Meteoclimatic station page for more information on your preferred station capabilities.

FieldTypeDescription
reference_timedatetime.datetimeTimestamp of weather measurement
conditionmeteoclimatic.Condition or strSingle-word weather condition (e.g. "sun", "suncloud", "rain", ...). If it's a recognized condition, it will be mapped to a value of the meteoclimatic.Condition enumerate, otherwise it will be stored as a string
temp_currentfloatCurrent temperature in Celsius
temp_maxfloatMaximum temperature in Celsius for the past 24 hours
temp_minfloatMinimum temperature in Celsius for the past 24 hours
humidity_currentfloatCurrent humidity in percentage points
humidity_maxfloatMaximum humidity in percentage points for the past 24 hours
humidity_minfloatMinimum humidity in percentage points for the past 24 hours
pressure_currentfloatCurrent atmospheric pressure in hPa units
pressure_maxfloatMaximum atmospheric pressure in hPa units for the past 24 hours
pressure_minfloatMinimum atmospheric pressure in hPa units for the past 24 hours
wind_currentfloatCurrent wind speed in km/h units
wind_maxfloatMaximum wind speed in km/h units for the past 24 hours
wind_bearingfloatWind bearing in degree units
rainfloatPrecipitation in mm units for the past 24 hours

Installation

Install with pip for your ease.

$ pip install pymeteoclimatic

Example

from meteoclimatic import MeteoclimaticClient

client = MeteoclimaticClient()
observation = client.weather_at_station("ESCAT4300000043206B")

print("Timestamp")
print("~~~~~~~~~")
print(observation.reception_time)
print()
print("Station")
print("~~~~~~~")
print(observation.station)
print()
print("Weather")
print("~~~~~~~")
print(observation.weather)

Output:

Timestamp
~~~~~~~~~
2020-06-09 13:45:55+00:00

Station
~~~~~~~
<class 'meteoclimatic.station.Station'>({'name': 'Reus - Nord (Tarragona)', 'code': 'ESCAT4300000043206B', 'url': 'http://www.meteoclimatic.net/perfil/ESCAT4300000043206B'})

Weather
~~~~~~~
<class 'meteoclimatic.weather.Weather'>({'reference_time': datetime.datetime(2020, 6, 9, 13, 45, 55, tzinfo=datetime.timezone.utc), 'condition': <Condition.sun: 'sun'>, 'temp_current': 24.0, 'temp_max': 24.2, 'temp_min': 13.7, 'humidity_current': 45.0, 'humidity_max': 80.0, 'humidity_min': 44.0, 'pressure_current': 1013.5, 'pressure_max': 1015.3, 'pressure_min': 1013.5, 'wind_current': 13.0, 'wind_max': 31.0, 'wind_bearing': 232.0, 'rain': 0.2})

Contributing

Please feel free to submit issues or fork the repository and send pull requests to update the library and fix bugs, implement support for new sentence types, refactor code, etc.

License

MIT License

Keywords

FAQs


Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc