Bird
Raised Fist0
Djangoframework~5 mins

Form validation (is_valid, cleaned_data) in Django

Choose your learning style10 modes available

Start learning this pattern below

Jump into concepts and practice - no test required

or
Recommended
Test this pattern10 questions across easy, medium, and hard to know if this pattern is strong
Introduction

Form validation helps check if the data a user enters is correct and safe before saving or using it. It stops mistakes and bad data from causing problems.

When you want to check if a user filled out a form correctly before saving their info.
When you need to clean or change user input to a safe or standard format.
When you want to show error messages if the user missed something or typed wrong.
When you want to get the cleaned, safe data from a form after checking it.
Syntax
Django
form = MyForm(request.POST)
if form.is_valid():
    data = form.cleaned_data
    # use data safely
else:
    # handle errors

is_valid() checks all fields and returns True if data is good.

cleaned_data holds the safe, cleaned data after validation.

Examples
Check if the form is valid, then get the cleaned name and email.
Django
form = ContactForm(request.POST)
if form.is_valid():
    name = form.cleaned_data['name']
    email = form.cleaned_data['email']
If the form is not valid, get the errors to show to the user.
Django
form = SignupForm(request.POST)
if not form.is_valid():
    errors = form.errors
Use get to safely access a field that might be optional.
Django
form = FeedbackForm(request.POST)
if form.is_valid():
    message = form.cleaned_data.get('message', '')
Sample Program

This example creates a simple form with name and age fields. It checks if the data is valid and prints the cleaned data. If invalid, it prints errors.

Django
from django import forms

class SimpleForm(forms.Form):
    name = forms.CharField(max_length=10)
    age = forms.IntegerField(min_value=0, max_value=120)

# Simulate POST data
post_data = {'name': 'Alice', 'age': '30'}

form = SimpleForm(post_data)

if form.is_valid():
    cleaned = form.cleaned_data
    print(f"Name: {cleaned['name']}")
    print(f"Age: {cleaned['age']}")
else:
    print("Errors:", form.errors)
OutputSuccess
Important Notes

Always call is_valid() before accessing cleaned_data.

If is_valid() returns False, cleaned_data is not available.

Use form errors to help users fix their input.

Summary

Use is_valid() to check if form data is good.

Access safe data with cleaned_data after validation.

Show errors if validation fails to guide users.

Practice

(1/5)
1. What does the is_valid() method do in a Django form?
easy
A. Saves the form data to the database
B. Clears all data from the form fields
C. Checks if the form data meets all validation rules
D. Generates HTML for the form

Solution

  1. Step 1: Understand the purpose of is_valid()

    This method runs all validation checks on the form data to ensure it is correct and complete.
  2. Step 2: Identify what is_valid() returns

    It returns True if all data passes validation, otherwise False.
  3. Final Answer:

    Checks if the form data meets all validation rules -> Option C
  4. Quick Check:

    Form validation = is_valid() [OK]
Hint: Remember: is_valid() means data is good to use [OK]
Common Mistakes:
  • Thinking is_valid() saves data
  • Confusing is_valid() with form rendering
  • Assuming is_valid() clears form fields
2. Which of the following is the correct way to access cleaned form data after validation?
easy
A. form.get_cleaned('field_name')
B. form.data['field_name']
C. form.fields['field_name']
D. form.cleaned_data['field_name']

Solution

  1. Step 1: Identify how cleaned data is stored

    After calling is_valid(), valid data is stored in cleaned_data dictionary.
  2. Step 2: Access cleaned data by field name

    You use form.cleaned_data['field_name'] to get the safe, validated value.
  3. Final Answer:

    form.cleaned_data['field_name'] -> Option D
  4. Quick Check:

    Access safe data = cleaned_data['field_name'] [OK]
Hint: Use cleaned_data after is_valid() to get safe inputs [OK]
Common Mistakes:
  • Using form.data which is raw input, not validated
  • Trying to call a non-existent method get_cleaned()
  • Accessing form.fields which holds field definitions, not data
3. Given this code snippet:
form = MyForm(request.POST)
if form.is_valid():
    name = form.cleaned_data['name']
else:
    errors = form.errors

What will errors contain if the form is invalid?
medium
A. A dictionary of error messages for each invalid field
B. An empty list
C. The cleaned data from the form
D. A boolean False value

Solution

  1. Step 1: Understand what form.errors holds

    When validation fails, form.errors contains error messages keyed by field names.
  2. Step 2: Differentiate errors from cleaned_data

    Errors are messages explaining what went wrong, not data or booleans.
  3. Final Answer:

    A dictionary of error messages for each invalid field -> Option A
  4. Quick Check:

    Invalid form errors = form.errors dict [OK]
Hint: form.errors holds messages, not data or booleans [OK]
Common Mistakes:
  • Confusing errors with cleaned_data
  • Expecting errors to be a list or boolean
  • Assuming errors is empty when invalid
4. What is wrong with this code?
form = MyForm(request.POST)
if form.is_valid:
    data = form.cleaned_data
medium
A. request.POST should be request.GET
B. Missing parentheses after is_valid, so validation is not called
C. cleaned_data should be called as a method
D. form variable is not defined

Solution

  1. Step 1: Check how is_valid is used

    The code uses form.is_valid without parentheses, so it references the method but does not call it.
  2. Step 2: Understand the effect of missing parentheses

    Without calling is_valid(), validation does not run and cleaned_data is not populated.
  3. Final Answer:

    Missing parentheses after is_valid, so validation is not called -> Option B
  4. Quick Check:

    Call is_valid() with () to validate [OK]
Hint: Always add () to call is_valid method [OK]
Common Mistakes:
  • Forgetting parentheses on is_valid()
  • Trying to call cleaned_data as a method
  • Confusing POST and GET without context
5. You want to create a form that only accepts an email if the user is over 18 years old. Which approach correctly uses is_valid() and cleaned_data to enforce this?
hard
A. Call is_valid(), then check cleaned_data['age'] to conditionally accept the email
B. Check form.data['age'] before calling is_valid()
C. Use form.errors before calling is_valid()
D. Assign cleaned_data before calling is_valid()

Solution

  1. Step 1: Understand validation order

    You must call is_valid() first to run all validations and populate cleaned_data.
  2. Step 2: Use cleaned_data to check age and decide if email is accepted

    After validation, cleaned_data['age'] is safe to use for conditional logic.
  3. Final Answer:

    Call is_valid(), then check cleaned_data['age'] to conditionally accept the email -> Option A
  4. Quick Check:

    Validate first, then use cleaned_data [OK]
Hint: Always validate before using cleaned_data for conditions [OK]
Common Mistakes:
  • Using raw data before validation
  • Accessing errors before validation
  • Trying to use cleaned_data before calling is_valid()