Почему я не могу добавить strptimes, только вычесть? - PullRequest
0 голосов
/ 20 мая 2018

Это отлично работает:

{{ strptime(states('input_datetime.music_alarm'), "%H:%M:%S") - strptime("10", "%M") }} 

Но это выдает ошибку:

{{ strptime(states('input_datetime.music_alarm'), "%H:%M:%S") + strptime("10", "%M") }} 

состояний ('input_datetime.music_alarm') равно времени, как 08: 00: 00

Я использую jinja2 для homeassistant.Вот ошибка.

Error doing job: Task exception was never retrieved
Traceback (most recent call last):
  File "/usr/lib/python3.5/asyncio/tasks.py", line 239, in _step
    result = coro.send(None)
  File "/srv/homeassistant/lib/python3.5/site-packages/homeassistant/components/automation/__init__.py", line 336, in async_trigger
    yield from self._async_action(self.entity_id, variables)
  File "/srv/homeassistant/lib/python3.5/site-packages/homeassistant/components/automation/__init__.py", line 425, in action
    yield from script_obj.async_run(variables)
  File "/srv/homeassistant/lib/python3.5/site-packages/homeassistant/helpers/script.py", line 158, in async_run
    await self._async_call_service(action, variables)
  File "/srv/homeassistant/lib/python3.5/site-packages/homeassistant/helpers/script.py", line 187, in _async_call_service
    self.hass, action, True, variables, validate_config=False)
  File "/srv/homeassistant/lib/python3.5/site-packages/homeassistant/helpers/service.py", line 72, in async_call_from_config
    config[CONF_SERVICE_DATA_TEMPLATE], variables))
  File "/srv/homeassistant/lib/python3.5/site-packages/homeassistant/helpers/template.py", line 56, in render_complex
    for key, item in value.items()}
  File "/srv/homeassistant/lib/python3.5/site-packages/homeassistant/helpers/template.py", line 56, in <dictcomp>
    for key, item in value.items()}
  File "/srv/homeassistant/lib/python3.5/site-packages/homeassistant/helpers/template.py", line 57, in render_complex
    return value.async_render(variables)
  File "/srv/homeassistant/lib/python3.5/site-packages/homeassistant/helpers/template.py", line 132, in async_render
    return self._compiled.render(kwargs).strip()
  File "/srv/homeassistant/lib/python3.5/site-packages/jinja2/environment.py", line 1008, in render
    return self.environment.handle_exception(exc_info, True)
  File "/srv/homeassistant/lib/python3.5/site-packages/jinja2/environment.py", line 780, in handle_exception
    reraise(exc_type, exc_value, tb)
  File "/srv/homeassistant/lib/python3.5/site-packages/jinja2/_compat.py", line 37, in reraise
    raise value.with_traceback(tb)
  File "<template>", line 1, in top-level template code
TypeError: bad operand type for unary -: 'datetime.datetime'

1 Ответ

0 голосов
/ 21 мая 2018

Вы ДОЛЖНЫ использовать timedelta и у вас есть многократная проблема в вашем коде.

1 / Неправильное использование datetime.datetime.strptime ()

>>> import datetime
>>> print(datetime.datetime.strptime("10", "%M"))
1900-01-01 00:10:00
>>> print(datetime.datetime.strptime('08:00:00', "%H:%M:%S"))
1900-01-01 08:00:00

Вы должны проанализировать полное datetime дляиметь правильное поведение.

2 / Вы не можете сложить два datetime

В принципе + запрещено избегать ошибок, вам нужно только -, потому что вам просто нужно инвертировать переменные в вашемВыражение с отрицательным значением timedelta.

>>> print(type(datetime.datetime.strptime("10", "%M") - datetime.datetime.strptime('08:00:00', "%H:%M:%S")))
<class 'datetime.timedelta'>
>>> print(datetime.datetime.strptime("10", "%M") - datetime.datetime.strptime('08:00:00', "%H:%M:%S"))
-1 day, 16:10:00
>>> print(datetime.datetime.strptime('08:00:00', "%H:%M:%S") - datetime.datetime.strptime("10", "%M"))
7:50:00

Вы можете видеть, что в обратном порядке это даст вам неправильно -1 day, 16:10:00, потому что это не может быть обработано без ошибок.

3 / Выможно зарегистрировать timedelta в вашем шаблоне

strptime () по умолчанию недоступен в Jinja2, поэтому сделайте это с timedelta () ...

Примерно так:

import datetime
from jinja2 import Template

jinga = Template('{{ strptime(states("input_datetime.music_alarm"), "%H:%M:%S") - timedelta(minutes=10) }} ')
jinga.globals['timedelta'] = datetime.timedelta
print(jinga.render())
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...