2.6 KiB

title description ha_category ha_release ha_iot_class ha_codeowners ha_domain ha_platforms ha_integration_type related ha_config_flow
File Instructions on how to integrate sensors which read from files into Home Assistant.
Notifications
Sensor
Utility
pre 0.7 Local Polling
@fabaff
file
notify
sensor
integration
docs title
/docs/configuration/ Configuration file
true

The File integration allows storing notifications in a file or setting up a sensor based on a file's content.

{% include integrations/config_flow.md %}

Notifications

Make sure that the file you want to use is added to the allowlist_external_dirs. The file will be created if it doesn't exist, but make sure the folder exists. Add the path of your configuration folder (for example, /config/file_notifications) to save the file there. Setting timestamp to true adds a timestamp to every logged entry. After creating a config entry, you can change the entry name, the name of the notify entity, or the entity ID, if you prefer.

To use notifications in automations or scripts, see the getting started with automation page.

Use the notify.send_message entity to store notification messages.

Sensor

The file sensor platform reads the entries from a plain-text file and shows the found value. Only the last line of the file is used. This is similar to do $ tail -n 1 sensor.txt on the command-line. Note that file paths must be added to allowlist_external_dirs.

Examples

In this section you find some real-life examples of how to use this sensor.

Entries as JSON

Assuming that the log file contains multiple values formatted as JSON as shown below:

[...]
{"temperature": 21, "humidity": 39}
{"temperature": 22, "humidity": 36}

This would require the following settings to extract the temperature:

  • Name: Temperature
  • File path: /config/sensor.json
  • Value template: {% raw %}{{ value_json.temperature }}{% endraw %}
  • Unit of measurement: "°C"

Entries as CSV

Assuming the log file contains multiple values formatted as CSV as shown below:

timestamp,temperature,humidity
1631472948,21,39
1631472949,22,36

This would require the following settings to extract the temperature:

  • Name: Temperature
  • File path: /config/sensor.csv
  • Value template: {% raw %}{{ value.split(",")[1] }}{% endraw %}
  • Unit of measurement: "°C"