Skip to content

Python script for importing Netatmo data into an InfluxDB

License

Notifications You must be signed in to change notification settings

ulthiel/NetatmoInflux

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

96 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

NetatmoInflux

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:

dashboard

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...

Installation

You will need some minor programming skills, but I guess otherwise you wouldn't be here.

Python

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.

Python packages

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.

InfluxDB

You need to set up an InfluxDB somewhere for storing the sensor values. I'm not going into details about this here, see here.

Initialization

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.

Setup

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:

locations

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.

modulelocations

You can check out the ModulesView table for a complete overview.

Import

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).

Running as service

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!

About

Python script for importing Netatmo data into an InfluxDB

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages