A Python script for importing Netatmo sensor data into an InfluxDB time series database. Using Chronograf or Grafana you can then run complex data analysis and create beautiful dashboards like this one here:
What makes this script a bit more powerful than others, I think, is that you can manage your past locations conveniently (in case you moved cities) and that data will be tagged accordingly in the InfluxDB. Well, and I just wanted to learn this stuff...
You will need some minor programming skills, but I guess otherwise you wouldn't be here.
You'll need Python 2. Note: version 2, not version 3. Both versions may co-exist on your system though, but note that in this case you may need to specifically call Python version 2 with python2
or something like this. If you have troubles installing Python, you can also try installing a pre-compiled bundle like Anaconda.
You'll need the additional Python packages influxdb (for InfluxDB) and pytz (for time zone conversions). It's easiest to install this with the pip tool:
pip install influxdb
pip install pytz
Depending on your system you may need to call these commands with sudo
. If you don't have pip, you should install it as described here.
You need to set up an InfluxDB somewhere for storing the sensor values. I'm not going into details about this here, see here.
Now, you should try to run the initialization script and follow the instructions:
python Initialize.py
-----------------------
| Add Netatmo account |
-----------------------
User: blah@blah.com
Password:
Do you want to save the password as clear text to the database?
If not, you have to enter it on any update.
Save (y/n)?: y
You have to grant client access for NetatmoInflux. If not done yet,
log into
https://dev.netatmo.com/dev/myaccount
and add an app called "NetatmoInflux". You will be given a client
id and a client secret.
Client id: blah
Client secret: blah
Account added
Getting modules for account blah
Added device blah (Indoor module) at location 1 (Sydney, Indoor)
Added module blah (Rain gauge) at location 2 (Sydney, Rain gauge)
Added module blah (Outdoor module) at location 3 (Sydney, Outdoor)
-----------------------
| Add InfluxDB |
-----------------------
Host: blah
Port: 8086
User: blah
Password:
Do you want to save the password as clear text to the database?
If not, you have to enter it on any update.
Save (y/n)?: y
Database: Environment
Use SSL (y/n)?: y
InfluxDB added
If you didn't get any errors, you're almost ready to go. Otherwise, you have to help yourself.
In principle, you could already run the import script Import.py
to import all data from the Netatmo server into your InfluxDB. Before you do this, hold on for a minute.
When I've written NetatmoInflux, I had a Netatmo module for almost 5 years already and I've moved cities a couple of times in between. I wanted to preserve the location information correctly as tags in the InfluxDB, so I had to tell the import script in which time windows the module was located where. This is done as follows (if you never moved or if you don't care, you can skip all of this).
The initialization script will create a local SQLite database named Netatmo.db
in which all the account information is stored. You can either view this database with the SQLite command line tool or you get the neat DB Browser for SQLite. There is a table called Locations to store location information. This should contain the location you've currently stored on the Netatmo server. But here you may add all your past locations as well. This is how my table looks like:
Now, with the table ModuleLocations you can manage the locations of your modules. For each module you have to provide a begin/end time stamp (this may be empty as well) describing the time window and then you have to give a location id as in the Locations table.
You can check out the ModulesView table for a complete overview.
The import script Import.py
imports the sensor data from the Netatmo server into your InfluxDB. Just run:
python Import.py
Import data for account blah
Importing data for Netatmo Indoor Module blah
Retrieving data from 2019-03-14 05:18:06 to now: 100%
5 data points for 1 timestamps received
Importing data for Netatmo Rain Gauge blah
Retrieving data from 2019-03-14 05:17:53 to now: 100%
1 data points for 1 timestamps received
Importing data for Netatmo Outdoor Module blah
Retrieving data from 2019-03-14 05:17:40 to now: 100%
2 data points for 1 timestamps received
The Netamo module id and the location will be stored as tags for each measurement. The script will always look for the latest available timestamp for each sensor and then starts retrieving data from this timestamp on. So, even if the script crashes (e.g., if the network connection breaks down), you can re-start it as if nothing happened and there won't be data corruption (I hope so).
To keep your data up to date you should run the import script as a service:
python Import.py --service
This will keep the script in a loop and execute the import every 10 minutes. Netatmo devices sent their values in this interval, so polling more often doesn't make sense and the Netatmo servers will eventually block you temporarily.
On a Linux server it's cleanest to have this run as a system service. It will depend on your Linux distribution how this is done. Under Ubuntu this works as follows. Register a new service via
sudo nano /lib/systemd/system/NetatmoInflux.service
and add the following:
[Unit]
Description=NetatmoInflux Service
After=multi-user.target
[Service]
Type=idle
ExecStart=/usr/bin/python /home/blah/NetatmoInflux/NetatmoInflux.py --service
[Install]
WantedBy=multi-user.target
Then change permissions on the service file:
sudo chmod 644 /lib/systemd/system/NetatmoInflux.service
Now, do
sudo systemctl daemon-reload
sudo systemctl enable NetatmoInflux
The service should then be started automatically at boot time. You can check this with
systemctl status NetatmoInflux
Happy analyzing!