Test greater than: gt
The gt test checks whether a value is strictly greater than another value. It is also available under the aliases greaterthan and >. When used with is, it reads naturally: value is gt(other).
While you can always use > directly in conditions, the gt test is essential when working with selectattr, select, and similar filters that require a test name as a string. This lets you filter collections by comparing attribute values without writing explicit loops.
Usage
Here’s how to use this template function. Copy any example and adjust it to your setup.
{% if 10 is gt(5) %}
Greater
{% endif %}
Greater
Function signature
The signature is a technical summary of this template function. It shows the name of the function, the values (called parameters) it accepts, and what type of data each parameter expects (for example, a piece of text or a number).
Function parameters that have a = with a value after them are optional. If you leave them out, the default value shown is used automatically. Function parameters without a default are required.
gt(
value: Any,
other: Any,
) -> bool
Function parameters
The following parameters can be provided to this function.
Aliases
This test can also be used as:
-
greaterthan-value is greaterthan(other) -
>-value is >(other)
Using with selectattr
Filter entities whose numeric attributes exceed a threshold.
{{
states.sensor
| selectattr("state", "gt", "25")
| map(attribute="name") | list
}}
['Outdoor Temperature']
Good to know
- When comparing entity state strings with numbers, convert first or wrap the threshold in quotes. String comparison puts
"9"above"10". - This is strict. A value equal to the threshold does not pass. Use
gefor greater-or-equal.
Try it yourself
Ready to test this? Open Developer tools > Template, paste the example into the Template editor, and watch the result update on the right. Edit the values to see how the function adapts to your own entitiesAn entity represents a sensor, actor, or function in Home Assistant. Entities are used to monitor physical properties or to control other entities. An entity is usually part of a device or a service. [Learn more].
More examples
Real scenarios where this function comes up in automations and templates. Copy any example and adapt it to your setup.
Filter values above a threshold
Use select to find numbers exceeding a limit.
{{ [10, 25, 30, 15, 40] | select("gt", 20) | list }}
[25, 30, 40]
Still stuck?
The Home Assistant community is quick to help: join Discord for real-time chat, post on the community forum with your template and expected result, or share on our subreddit /r/homeassistant.
AI assistants like ChatGPT or Claude can also explain or fix templates when you describe what you want in plain language.
Related template functions
These functions work well alongside this one:
-
Test greater than or equal: ge - Tests if a value is greater than or equal to another. Also known as >=.
-
Test less than: lt - Tests if a value is less than another. Also known as lessthan or <.
-
Test less than or equal: le - Tests if a value is less than or equal to another. Also known as <=.
-
Test equality: eq - Tests if two values are equal. Also known as equalto or ==.
-
Test not equal: ne - Tests if two values are not equal. Also known as !=.