Bird
Raised Fist0
Pythonprogramming~5 mins

Private attributes in Python

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

Private attributes help keep some parts of an object hidden so others can't change them by mistake.

When you want to protect important data inside an object from being changed directly.
When you want to control how data inside an object is accessed or modified.
When you want to hide details that users of your class don't need to see.
When you want to avoid accidental changes to internal variables.
When you want to make your code safer and easier to maintain.
Syntax
Python
class ClassName:
    def __init__(self):
        self.__private_attribute = None

Private attributes start with two underscores __.

This makes Python change the name internally to avoid easy access from outside.

Examples
This creates a private attribute __speed inside the Car class.
Python
class Car:
    def __init__(self, speed):
        self.__speed = speed
Private attribute __name is accessed safely using a method get_name.
Python
class Person:
    def __init__(self, name):
        self.__name = name

    def get_name(self):
        return self.__name
Sample Program

This program shows a private attribute __balance in a BankAccount class. It can only be changed by methods inside the class. Trying to access it directly causes an error.

Python
class BankAccount:
    def __init__(self, balance):
        self.__balance = balance  # private attribute

    def deposit(self, amount):
        if amount > 0:
            self.__balance += amount

    def get_balance(self):
        return self.__balance

account = BankAccount(100)
print(account.get_balance())  # prints 100
account.deposit(50)
print(account.get_balance())  # prints 150

# Trying to access private attribute directly
try:
    print(account.__balance)
except AttributeError as e:
    print(e)
OutputSuccess
Important Notes

Private attributes are not truly hidden but renamed internally (name mangling).

You can still access them using _ClassName__attribute but it is not recommended.

Use private attributes to protect important data and keep your code clean.

Summary

Private attributes start with two underscores __ to hide them.

They help protect data inside objects from outside changes.

Access private attributes using methods inside the class.

Practice

(1/5)
1. What is the main purpose of using private attributes (starting with __) in a Python class?
easy
A. To speed up the program execution
B. To hide the attribute from outside the class and protect it
C. To make the attribute accessible everywhere
D. To make the attribute a global variable

Solution

  1. Step 1: Understand private attribute naming

    Private attributes start with double underscores to hide them from outside access.
  2. Step 2: Purpose of hiding attributes

    This protects the data inside the object from accidental or unauthorized changes.
  3. Final Answer:

    To hide the attribute from outside the class and protect it -> Option B
  4. Quick Check:

    Private attributes = data protection [OK]
Hint: Private attributes start with __ to hide data inside class [OK]
Common Mistakes:
  • Thinking private means accessible everywhere
  • Confusing private with global variables
  • Believing private speeds up code
2. Which of the following is the correct way to define a private attribute named age in a Python class?
easy
A. self.___age
B. self.age
C. self._age
D. self.__age

Solution

  1. Step 1: Identify private attribute syntax

    Private attributes start with exactly two underscores, like __age.
  2. Step 2: Check options

    self.__age uses self.__age, which is correct. self.age is public, self._age is protected (single underscore), self.___age has three underscores which is invalid.
  3. Final Answer:

    self.__age -> Option D
  4. Quick Check:

    Private attribute = double underscore [OK]
Hint: Private attribute = double underscore before name [OK]
Common Mistakes:
  • Using single underscore instead of double
  • Adding too many underscores
  • Forgetting underscores
3. What will be the output of this code?
class Person:
    def __init__(self, name):
        self.__name = name
    def get_name(self):
        return self.__name

p = Person('Anna')
print(p.get_name())
print(p.__name)
medium
A. Anna\nAnna
B. AttributeError\nAnna
C. Anna\nAttributeError
D. AttributeError\nAttributeError

Solution

  1. Step 1: Understand private attribute access

    The attribute __name is private and cannot be accessed directly outside the class.
  2. Step 2: Check print statements

    Calling p.get_name() returns 'Anna' correctly. But p.__name causes AttributeError because it's private.
  3. Final Answer:

    Anna\nAttributeError -> Option C
  4. Quick Check:

    Private attribute direct access = AttributeError [OK]
Hint: Private attributes cause error if accessed directly outside class [OK]
Common Mistakes:
  • Expecting direct access to private attribute
  • Ignoring AttributeError on private access
  • Confusing method call with attribute access
4. Find the error in this code and fix it:
class Car:
    def __init__(self, model):
        self.__model = model

c = Car('Tesla')
print(c.__model)
medium
A. Add a method inside class to return __model
B. No error, code runs fine
C. Remove underscores from __model
D. Change __model to _model to fix access

Solution

  1. Step 1: Identify the error

    Accessing c.__model outside the class causes AttributeError because __model is private.
  2. Step 2: Fix by adding a getter method

    Adding a method inside the class to return self.__model allows safe access.
  3. Final Answer:

    Add a method inside class to return __model -> Option A
  4. Quick Check:

    Private attribute access needs class method [OK]
Hint: Use class method to access private attributes outside class [OK]
Common Mistakes:
  • Trying to access private attribute directly
  • Removing underscores breaks privacy
  • Ignoring need for getter method
5. You want to store a private attribute __balance in a BankAccount class and allow safe updating only through a method that adds money. Which code snippet correctly implements this?
hard
A. class BankAccount: def __init__(self): self.__balance = 0 def add_money(self, amount): self.__balance += amount def get_balance(self): return self.__balance
B. class BankAccount: def __init__(self): self._balance = 0 def add_money(self, amount): self._balance += amount def get_balance(self): return self._balance
C. class BankAccount: def __init__(self): self.balance = 0 def add_money(self, amount): self.balance += amount def get_balance(self): return self.balance
D. class BankAccount: def __init__(self): self.__balance = 0 def add_money(self, amount): self.balance += amount def get_balance(self): return self.__balance

Solution

  1. Step 1: Check private attribute usage

    class BankAccount: def __init__(self): self.__balance = 0 def add_money(self, amount): self.__balance += amount def get_balance(self): return self.__balance uses self.__balance consistently and privately.
  2. Step 2: Verify method updates and access

    The add_money method safely updates __balance, and get_balance returns it correctly.
  3. Final Answer:

    The code using self.__balance consistently in all methods -> Option A
  4. Quick Check:

    Private attribute updated only inside class methods [OK]
Hint: Update private attributes only via class methods [OK]
Common Mistakes:
  • Updating private attribute outside class
  • Mixing private and public attribute names
  • Not providing method to access private data