ZetCode

Python None Keyword

last modified February 25, 2025

The None keyword in Python represents the absence of a value. It is a special constant used to denote null values or empty states. This tutorial covers None's behavior, common use cases, and comparison techniques.

None is the sole instance of the NoneType class. It evaluates to False in boolean contexts and serves as a default return value for functions that don't explicitly return anything. Understanding None is crucial for handling optional values and missing data.

Checking for None

This example demonstrates the proper way to check for None using the is operator.

check_none.py
value = None

if value is None:
    print("No value provided")  # Output: No value provided
else:
    print("Value exists")

Always use is or is not when comparing to None. This ensures you're checking identity rather than equality, as None is a singleton.

Function Return Values

This example shows how functions return None implicitly when no return statement is present.

implicit_return.py
def no_return():
    pass

result = no_return()
print(result)  # Output: None

Python functions always return None unless specified otherwise. The pass statement creates an empty function body with no return value.

Using None as Default Parameter

This example demonstrates using None for mutable default parameters to avoid unexpected behavior.

default_parameter.py
def add_item(item, collection=None):
    if collection is None:
        collection = []
    collection.append(item)
    return collection

list1 = add_item(1)
list2 = add_item(2)
print(list1, list2)  # Output: [1] [2]

Using None as a default parameter prevents shared state between function calls. A new list is created each time the default value is needed.

None in Data Structures

This example shows how None can be used as a placeholder in data structures.

data_structure.py
user_data = {
    "name": "Alice",
    "age": None,
    "email": "alice@example.com"
}

if user_data["age"] is None:
    print("Age not provided")  # Output: Age not provided

None serves as a useful placeholder for missing or optional data in dictionaries and other data structures.

None vs Boolean Checks

This example demonstrates the difference between None and boolean evaluations.

boolean_check.py
value = None

if value:
    print("Truthy value")
else:
    print("Falsy value")  # Output: Falsy value

value = 0
print(value is None)  # Output: False

While None is falsy, other values like 0 or empty collections are also falsy. Always use explicit None checks when testing for absence of value.

Type Checking None

This example shows how to check an object's type against NoneType.

type_check.py
from types import NoneType

value = None
print(isinstance(value, NoneType))  # Output: True

While direct type checks are rare, this demonstrates None's unique type. Use is None for most practical cases.

Best Practices for Using None

Source

Python None Documentation

In this article, we have explored the Python None keyword and its role in representing null values, function returns, and optional data handling.

Author

My name is Jan Bodnar, and I am a passionate programmer with extensive programming experience. I have been writing programming articles since 2007. To date, I have authored over 1,400 articles and 8 e-books. I possess more than ten years of experience in teaching programming.

List all Python tutorials.