IndentationError is raised by the parser when Python sees a block that is missing, misaligned, or mixed between tabs and spaces.
Focus on the parser's block rules, the three common error messages, and how to spot the exact line where indentation breaks.
A strong understanding of IndentationError should include how Python tokenizes `INDENT` and `DEDENT` and how empty blocks use `pass`.
Python IndentationError Missing Blocks Unexpected Indent and Tabs vs Spaces should be studied as a practical Python lesson, not as a label. Start by naming the input, the rule that changes the input, and the result a learner should be able to predict after reading the page.
In the python > errors > indentation-error page, the notes should connect the definition with a working scenario, a mistake that beginners actually make, and the exact check that proves the fix. That makes the topic useful for coding, debugging, and interview revision.
The IndentationError is one of the most common Python errors for beginners. It occurs when Python encounters incorrect or inconsistent indentation in your code. Unlike most programming languages that use braces {} for code blocks, Python uses indentation to define code structure.
# ❌ Problem
if x > 5:
print("Greater") # Missing indentation!
# ✅ Solution: Add proper indentation (4 spaces recommended)
if x > 5:
print("Greater")
# ✅ Configure your editor:
# - Use 4 spaces per indentation level
# - Convert tabs to spaces
# - Enable "show whitespace" to see indentation
The most common cause - forgetting to indent code after statements that require a code block.
Python 3 doesn't allow mixing tabs and spaces. This often happens when copying code from different sources.
Using different numbers of spaces for indentation at the same level causes this error.
Adding indentation where it's not expected, usually at the start of a file or after a complete statement.
Python requires at least one statement in every code block. Use pass for empty blocks.
def greet(name):
print(f"Hello, {name}") # IndentationError!
if age >= 18:
print("Adult") # IndentationError!
for i in range(5):
print(i) # IndentationError!
def greet(name):
print(f"Hello, {name}") # Properly indented
if age >= 18:
print("Adult") # Properly indented
for i in range(5):
print(i) # Properly indented
def calculate():
x = 10 # 4 spaces
y = 20 # Tab character - IndentationError!
return x + y
def calculate():
x = 10 # 4 spaces
y = 20 # 4 spaces (consistent)
return x + y
# Configure your editor to convert tabs to spaces
# VS Code: "editor.insertSpaces": true
# PyCharm: Settings → Editor → Code Style → Python → Use tab character: unchecked
def process_data():
if True:
print("Start") # 4 spaces
print("Middle") # 2 spaces - IndentationError!
print("End") # 4 spaces
def process_data():
if True:
print("Start") # 4 spaces
print("Middle") # 4 spaces (consistent)
print("End") # 4 spaces
print("Hello") # Unexpected indent at file start!
x = 10
y = 20 # Unexpected indent after complete statement!
print("Hello") # No indentation at file start
x = 10
y = 20 # Same indentation level
def todo_function():
# Will implement later
# IndentationError: expected an indented block
if condition:
# IndentationError!
def todo_function():
# Will implement later
pass # Use pass for empty blocks
if condition:
pass # Placeholder
# Or use ellipsis (Python 3+)
def another_function():
... # Also valid for empty blocks
Python IndentationError Missing Blocks Unexpected Indent and Tabs vs Spaces matters in Python because it changes how a program is written, tested, or debugged. The page should explain the normal flow first: what the developer writes, what the runtime or platform does, and what result should appear.
When teaching Python IndentationError Missing Blocks Unexpected Indent and Tabs vs Spaces, avoid stopping at syntax. Show the surrounding decision: why this feature is chosen, what problem it removes, and what would become harder if the feature were not used.
The strongest notes for Python IndentationError Missing Blocks Unexpected Indent and Tabs vs Spaces explain where the idea stops working. Add cases for missing input, wrong order, incompatible types, duplicate values, empty collections, failed requests, or configuration mismatch when those cases fit the lesson.
Readers should leave the page knowing how to inspect a bad result. For Python IndentationError Missing Blocks Unexpected Indent and Tabs vs Spaces, that means checking the relevant value, state, dependency, selector, query, route, class, or runtime message before changing code randomly.
def review_python-indentationerror-missing-blocks-unexpected-indent-and-tabs-vs-spaces():
value = "sample"
if value:
print("Python IndentationError Missing Blocks Unexpected Indent and Tabs vs Spaces: normal path is ready")
else:
print("Python IndentationError Missing Blocks Unexpected Indent and Tabs vs Spaces: handle the empty path first")
review_python-indentationerror-missing-blocks-unexpected-indent-and-tabs-vs-spaces()
items = []
if not items:
print("Python IndentationError Missing Blocks Unexpected Indent and Tabs vs Spaces: no data available, show a fallback")
else:
print(items[0])
Memorizing Python IndentationError Missing Blocks Unexpected Indent and Tabs vs Spaces without the situation where it is useful.
Connect Python IndentationError Missing Blocks Unexpected Indent and Tabs vs Spaces to a concrete Python task.
Testing Python IndentationError Missing Blocks Unexpected Indent and Tabs vs Spaces only with the perfect input.
Include empty, missing, duplicate, incompatible, or failed cases when relevant.
Changing code before reading the visible symptom or error message.
Inspect the output, state, configuration, or stack trace connected to Python IndentationError Missing Blocks Unexpected Indent and Tabs vs Spaces.
Memorizing Python IndentationError Missing Blocks Unexpected Indent and Tabs vs Spaces without the situation where it is useful.
Connect Python IndentationError Missing Blocks Unexpected Indent and Tabs vs Spaces to a concrete Python task.
IndentationError occurs when code has incorrect or inconsistent indentation, such as missing indentation after colons, mixing tabs and spaces, or using inconsistent spacing levels.
Always use spaces (4 spaces per level recommended by PEP 8). Python 3 doesn't allow mixing tabs and spaces. Configure your editor to convert tabs to spaces automatically.
Add proper indentation (4 spaces) after statements that require code blocks (if, for, while, def, class). If the block is empty, use pass or ... as a placeholder.
Enable "show whitespace" or "render whitespace" in your editor settings. In VS Code: View → Render Whitespace. This makes spaces and tabs visible.
Run python -tt yourfile.py to detect tab/space mixing. Use linters like pylint or flake8, or formatters like black or autopep8 to automatically fix indentation.
Explore 500+ free tutorials across 20+ languages and frameworks.