Tutorials Logic, IN info@tutorialslogic.com

IndentationError in Python: Causes, Fixes, Examples & Interview Tips

What is This Error?

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.

Common Causes

  • Missing indentation after colon (:) in if, for, while, def, class statements
  • Mixing tabs and spaces for indentation
  • Inconsistent indentation levels (2 spaces vs 4 spaces)
  • Extra or unexpected indentation
  • Copy-pasting code with different indentation styles

Quick Fix (TL;DR)

Quick Solution

Quick Solution
# ❌ 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

Common Scenarios & Solutions

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.

Problem

Problem
def greet(name):
print(f"Hello, {name}")  # IndentationError!

if age >= 18:
print("Adult")  # IndentationError!

for i in range(5):
print(i)  # IndentationError!

Solution

Solution
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

Problem

Problem
def calculate():
    x = 10  # 4 spaces
	y = 20  # Tab character - IndentationError!
    return x + y

Solution

Solution
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

Problem

Problem
def process_data():
    if True:
        print("Start")  # 4 spaces
      print("Middle")  # 2 spaces - IndentationError!
        print("End")    # 4 spaces

Solution

Solution
def process_data():
    if True:
        print("Start")  # 4 spaces
        print("Middle")  # 4 spaces (consistent)
        print("End")    # 4 spaces

Problem

Problem
print("Hello")  # Unexpected indent at file start!

x = 10
    y = 20  # Unexpected indent after complete statement!

Solution

Solution
print("Hello")  # No indentation at file start

x = 10
y = 20  # Same indentation level

Problem

Problem
def todo_function():
    # Will implement later
# IndentationError: expected an indented block

if condition:
# IndentationError!

Solution

Solution
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

Best Practices to Avoid This Error

  • Use 4 spaces per indentation level - PEP 8 standard for Python code
  • Never mix tabs and spaces - Configure your editor to convert tabs to spaces
  • Enable "show whitespace" in your editor - Makes indentation visible
  • Use a Python-aware editor - VS Code, PyCharm, or Sublime with Python plugins
  • Run python -tt script.py - Detects tab/space mixing issues
  • Use autopep8 or black - Auto-format your code to fix indentation
  • Be consistent - Stick to one indentation style throughout your project

Related Errors

Frequently Asked Questions

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.

Ready to Level Up Your Skills?

Explore 500+ free tutorials across 20+ languages and frameworks.