20 lines
1.1 KiB
Markdown
20 lines
1.1 KiB
Markdown
---
|
|
title: Python Truth Value Testing
|
|
---
|
|
<a href='https://docs.python.org/3/library/stdtypes.html#truth-value-testing' target='_blank' rel='nofollow'>Python Docs - Truth Value Testing</a>
|
|
|
|
Any object can be tested for truth value, for use in an `if` or `while` condition or as operand of a Boolean operation like `and`, `or`, or `not`.
|
|
|
|
The following values are considered false:
|
|
|
|
* `None`
|
|
* `False`
|
|
* zero of any numeric type, for example, `0`, `0.0`, `0j`, `Decimal(0)`, `Fraction(0, 1)`.
|
|
* any empty sequence, for example, `''`, `()`, `[]`, `set()`, `range(0)`.
|
|
* any empty mapping, for example, `{}`.
|
|
* instances of user-defined classes, if the class defines a `__bool__()` or `__len__()` method, when that method returns `False` or `0`.
|
|
|
|
All other values are considered true -- so objects of many types are always true.
|
|
|
|
Operations and built-in functions that have a Boolean result always return `0` or `False` for false and `1` or `True` for true, unless otherwise stated. (Important exception: the Boolean operations `or` and `and` always return one of their operands.)
|