With some help I’ve managed to perform some time calculations with helpers and they now work as expected when changed in the dashboard. I’d like to be able to set a helper to the time my current energy supplier changes from cheap to expensive energy. This can change when changing supplier so I want to use a helper just to make life easier. The time this happens is set in UTC, it does not change with daylight savings, which is plus 1 hour for me.
However, I’m stumped on how I can set a time in a helper that is in UTC. I can set this value in local and change to UTC, but I can’t see an obvious way to flag this as UTC and then calculate local.
I’d like the helper input_datetime.economy_7_off_time_utc to be set, or calculated, as UTC in the following automation. To me it looks like as soon as I do anything with the helper the result is local, I haven’t yet found a simple way to keep it as UTC?
So, trying to understand how this string is generated… state_attr confirms my helper is a timestamp, then timestamp_custom strips out the time with '%H:%M' and local=True converts to local. Therefore somewhere there’s an assumption the helper is UTC?
I can then convert this string to a timestamp and do my calculation?
The template does not use the helper state. Each input date time helper has a timestamp attribute (Look at the attributes in dev tools / states). This is referenced to the Unix epoch if no date is included.
The template converts this attribute to a HH:MM:SS string in UTC.
Yes you can then use this in your calculation. You will probably have to convert it to a datetime object or timestamp before doing any math.
Thank you, I think My simple calculation of taking a Unix time subtracting an offset is taking on a WHOLE new aspect of learning, confusion and exasperation.
A positive learning experience though. I don’t remember time calculations being this difficult back in the day when I used to do this in C. Seems like a lot of type casting
Finally with some time spent in template editor, I set a time helper to when my cheap energy finishes, this time is in GMT/UTC, this will only change if my supplier changes and this time is changed. I set another helper that specifies how long I (the Mrs tells me) wants the rail to be on. This formula then work out the time, in local, taking into account daylight savings, BST for me. This template seems VERY complicated for what I thought was going to be a straightforward process.
Anyway, if anybody else encounters a similar issue here’s the solution I’ve arrived at with help and hopefully it will help others. OR, if someone has a simpler more eligant solution I’m (really) open to ideas!
Id like to do conversion other way, local to utc.
I have input_datetime.latauksen_ajastus_lahtoaika that has value 06:00:00, and i need to convert to utc 03:00:00, but didnt figure it.
Both lines gives same output
If i set local:true it gives +02:00:00 instead of +03:00:00
I use now() in different sensor, it shows correct time with correct local time.
Im confused, could you please explain what is happening?
If I use utcnow() it gives correct utc time 2024-06-13 09:40:39.833168+00:00
And when i use now() it gives correct local time 2024-06-13 12:41:02.870990+03:00
Timezone is set in settings (GMT+2:00 Helsinki) what should be correct as summertime is +3:00 and that is what im seeing as local time.
I just got an answer from someone more knowledgeable than me.
Time only timestamps assume the date is 1st of January 1970. Which for me means daylight savings would be active, which is why I am seeing +11 hrs difference instead of +10.