Create an image suitable to be displayed on a SoluM ST-GR29000 ePaper price tag. The image shows the current temperature and pressure, the general weather as a pictogram, the temperature forecast in one hour, the pressure forecast in one day, the date and time of the image creation and a graph of temperature and pressure forcast for the next 48 hours. The weather data is gathered from OpenWeatherMap OpenWeatherMap using their OneCall-API v3.0
The python script currently uses Python 3.9.2 with PyYAML 6.0, Pillow 9.3.0, pyowm main branch and matplotlib 3.6.2 Especially if you run the scripts from cron, make sure the packages are installed in the system, not in the user path only. Make sure you have the right version installed in the system paths, it is quite confusing if you test the scripts as a regular user and exhibit strange behaviour when run from cron due to different versions installed in the system and user path. Don't ask how I know... To access OpenWeatherMap, you need to create a free account and generate an API key for a paid subscription to the OneCall-API. The subscription includes 1000 free calls to the API per day, so normally there should be no charge. You can limit the number of calls per day to 1000, so you will never be charged even when a script runs wild and makes excessive calls.
sudo pip install Pillow matplotlib pyyaml
Currently as of 2025/01/01 the pyowm release package 3.3.0 does not include the API 3.0, so install the current main branch:
pip uninstall pyowm # only required if pyowm is already installed
git clone https://github.com/csparpa/pyowm.git
cd pyowm
pip install -r requirements.txt # install dependencies
python setup.py install # install develop branch code
Ignore the message about deprecated installation methods. Note that the current main branch installs as 3.3.0 too!
A generated image looks similar to the following example:
Description: Current temperature 11°C, rising to 11.2°C in the next hour. Current pressure 1010hPa, rising to 1028hPa in the next 24 hours. Current condition scattered with sun and rain. Graph for the next 48 hours, temperature in red, pressure in black. Image created on February 16th, 2024 at 10:17:03
Configuration is done in config.yml that resides beneath owm.py. If you download the package for the first time, copy the sample file to config.yl and edit it. Paste your OWM API key to config.yml and set your city and country:
owm:
api_key: 0123456789...abcdef
location: Hamburg
country: DE
See more configurable values in the configuration file.
Running the script with:
python owm.py
should give no error message and the file weather.jpg should be updated. The image fits the price tags orientation with the barcode to the left.
The location query does not check for the result set. It expects at least one hit and uses the first one. If no hit is found, it fails with an exception:
location = 'Gndfertyz'
country = 'DE'
Traceback (most recent call last):
File "/home/pi/owm/owm.py", line 119, in <module>
one_call = getOneCall(api_key, location, country)
File "/home/pi/owm/owm.py", line 44, in getOneCall
home = homelist[0]
IndexError: list index out of range
Error handling is missing at other places too, so if anything fails do not expect the script to finish gracefully.