Skip to content

Create a weather image suitable to be displayed on a SoluM ST-GR290000 ePaper display

License

Notifications You must be signed in to change notification settings

dl6lr/eink-weatherforecast

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

14 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

eink-weatherforecast

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

Prerequisites

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!

The generated image

A generated image looks similar to the following example:

weather display

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

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.

Known bugs

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.

About

Create a weather image suitable to be displayed on a SoluM ST-GR290000 ePaper display

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages