This document is available in the following languages (non-English versions may not be complete or up to date):
pywws is a collection of Python scripts to read, store and process data from popular USB wireless weather stations such as Elecsa AstroTouch 6975, Watson W-8681, WH-1080PC, WH1080, WH1081, WH3080 etc. I assume any model that is supplied with the EasyWeather Windows software is compatible, but cannot guarantee this.
The software has been developed to run in a low power, low memory environment such as a router. It can be used to create graphs and web pages showing recent weather readings, typically updated every hour. It can also send data to services such as Weather Underground and post messages to Twitter.
I have written this software to meet my needs, but have tried to make it adaptable to other people’s requirements. You may want to edit some or all of the modules, or write some new ones, to get it to do exactly what you want. One of the reasons for using Python is that it makes such alterations so easy. Don’t be afraid, just jump in and have a go.
The software you’ll need to run pywws depends on what you plan to do with it. In particular, there is a choice of USB library, to suit what’s available on different operating systems.
- Python version 2.5 or higher (note: Python 3 support is under development - some things may not work properly)
- USB library option 1 (preferred, except on MacOS):
- USB library option 2 (if PyUSB 1.0 is not available):
- USB library option 3 (best for MacOS):
- USB library option 4:
- For graph drawing:
- gnuplot v4.2 or higher
- For secure website uploading (sftp)
- For Twitter updates:
- tweepy v2.0 or higher
- simplejson
- To create new language translations:
- To ‘compile’ the documentation:
The simplest way to obtain pywws is to use pip to install it directly from the Python Package Index (PyPI). Note that this will probably require ‘root’ privileges, so will need to be run using sudo:
sudo pip install pywws
If you don’t have root privileges, or don’t want to install pywws, you can download a zip or tar.gz file from PyPI and then extract the files into a convenient directory on your computer.
The PyPI files contain a snapshot release of the software - a new one is issued every few months. If you’d like to keep up to date with latest developments of pywws, you should use git to clone the pywws repository:
git clone https://github.com/jim-easterbrook/pywws.git
After doing so you can compile the documentation and language localisation files (which will require the sphinx and gettext dependencies):
cd pywws
python setup.py build_sphinx
python setup.py msgfmt
For more details, see How to get started with pywws.
The method used to upgrade pywws depends on how you originally obtained it. If you downloaded a zip or tar.gz file, you just need to do the same again, with the new version, then delete your old download when you’ve finished setting up the new one. (Note that upgrading is much easier if you do not keep your templates, user modules and weather data in the same directory as the downloaded files.) If you used pip you just need to repeat the command. git users just need to do a git pull command.
Some new versions of pywws have changed what’s stored in the hourly, daily or monthly summary data files. These new versions are incompatible with processed data from earlier versions. The pywws.Reprocess module regenerates all the summary data. It should be run after any major upgrade.
Documentation is included with pywws downloads, and is also available online. A good starting place is How to get started with pywws which describes in more detail how to install pywws.
If you have questions not answered in the documentation, please join the pywws Google mailing list / discussion group and ask there. Note that your first message to the group will not appear immediately – new posters have to be approved by a moderator, to prevent spam messages.
I would not have been able to get any information from the weather station without access to the source of Michael Pendec’s “wwsr” program. I am also indebted to Dave Wells for decoding the weather station’s “fixed block” data.
Last of all, a big thank you to all the pywws users who have helped with questions and suggestions, and especially to those who have translated pywws and its documentation into other languages.
This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version.
This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA