mirror of
https://github.com/home-assistant/core.git
synced 2025-07-18 18:57:06 +00:00
Allow decimal places to be set
This commit is contained in:
parent
6606d2a73c
commit
27845d3fc5
@ -14,6 +14,7 @@ sensor:
|
|||||||
command: sensor_command
|
command: sensor_command
|
||||||
unit_of_measurement: "°C"
|
unit_of_measurement: "°C"
|
||||||
correction_factor: 0.0001
|
correction_factor: 0.0001
|
||||||
|
decimal_places: 0
|
||||||
|
|
||||||
Variables:
|
Variables:
|
||||||
|
|
||||||
@ -33,17 +34,20 @@ correction_factor
|
|||||||
*Optional
|
*Optional
|
||||||
A float value to do some basic calculations.
|
A float value to do some basic calculations.
|
||||||
|
|
||||||
|
decimal_places
|
||||||
|
*Optional
|
||||||
|
Number of decimal places of the value. Default is 0.
|
||||||
|
|
||||||
For more details about this platform, please refer to the documentation at
|
For more details about this platform, please refer to the documentation at
|
||||||
https://home-assistant.io/components/sensor.command_sensor.html
|
https://home-assistant.io/components/sensor.command_sensor.html
|
||||||
"""
|
"""
|
||||||
import logging
|
import logging
|
||||||
from subprocess import check_output, CalledProcessError
|
import subprocess
|
||||||
from datetime import timedelta
|
from datetime import timedelta
|
||||||
|
|
||||||
from homeassistant.helpers.entity import Entity
|
from homeassistant.helpers.entity import Entity
|
||||||
from homeassistant.util import Throttle
|
from homeassistant.util import Throttle
|
||||||
|
|
||||||
|
|
||||||
_LOGGER = logging.getLogger(__name__)
|
_LOGGER = logging.getLogger(__name__)
|
||||||
|
|
||||||
DEFAULT_NAME = "Command Sensor"
|
DEFAULT_NAME = "Command Sensor"
|
||||||
@ -66,18 +70,21 @@ def setup_platform(hass, config, add_devices_callback, discovery_info=None):
|
|||||||
data,
|
data,
|
||||||
config.get('name', DEFAULT_NAME),
|
config.get('name', DEFAULT_NAME),
|
||||||
config.get('unit_of_measurement'),
|
config.get('unit_of_measurement'),
|
||||||
config.get('correction_factor', 1.0)
|
config.get('correction_factor', None),
|
||||||
|
config.get('decimal_places', 0)
|
||||||
)])
|
)])
|
||||||
|
|
||||||
|
|
||||||
class CommandSensor(Entity):
|
class CommandSensor(Entity):
|
||||||
""" Represents a sensor that is returning a value of a shell commands. """
|
""" Represents a sensor that is returning a value of a shell commands. """
|
||||||
def __init__(self, data, name, unit_of_measurement, corr_factor):
|
def __init__(self, data, name, unit_of_measurement, corr_factor,
|
||||||
|
decimal_places):
|
||||||
self.data = data
|
self.data = data
|
||||||
self._name = name
|
self._name = name
|
||||||
self._state = False
|
self._state = False
|
||||||
self._unit_of_measurement = unit_of_measurement
|
self._unit_of_measurement = unit_of_measurement
|
||||||
self._corr_factor = corr_factor
|
self._corr_factor = float(corr_factor)
|
||||||
|
self._decimal_places = decimal_places
|
||||||
self.update()
|
self.update()
|
||||||
|
|
||||||
@property
|
@property
|
||||||
@ -101,7 +108,11 @@ class CommandSensor(Entity):
|
|||||||
value = self.data.value
|
value = self.data.value
|
||||||
|
|
||||||
if value is not None:
|
if value is not None:
|
||||||
self._state = int(round(float(value)) * self._corr_factor)
|
if self._corr_factor is not None:
|
||||||
|
self._state = round((int(value) * self._corr_factor),
|
||||||
|
self._decimal_places)
|
||||||
|
else:
|
||||||
|
self._state = value
|
||||||
|
|
||||||
|
|
||||||
# pylint: disable=too-few-public-methods
|
# pylint: disable=too-few-public-methods
|
||||||
@ -118,7 +129,7 @@ class CommandSensorData(object):
|
|||||||
_LOGGER.info('Running command: %s', self.command)
|
_LOGGER.info('Running command: %s', self.command)
|
||||||
|
|
||||||
try:
|
try:
|
||||||
return_value = check_output(self.command.split())
|
return_value = subprocess.check_output(self.command.split())
|
||||||
self.value = return_value.strip().decode('utf-8')
|
self.value = return_value.strip().decode('utf-8')
|
||||||
except CalledProcessError:
|
except subprocess.CalledProcessError:
|
||||||
_LOGGER.error('Command failed: %s', self.command)
|
_LOGGER.error('Command failed: %s', self.command)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user