Python journey | Day 7

Python journey | Day 7

On Day 7 let's delve into the basics of Object-Oriented Programming (OOP), covering classes, objects, attributes, methods, inheritance, and polymorphism.

Classes and Objects:

Classes:

A class is a blueprint or template for creating objects. It defines the properties (attributes) and behaviors (methods) that objects of that class will have.

class Car:
    # Attributes
    def __init__(self, make, model, year):
        self.make = make
        self.model = model
        self.year = year
    
    # Methods
    def info(self):
        return f"{self.year} {self.make} {self.model}"        

Objects:

An object is an instance of a class. It's created based on the blueprint provided by the class.

car1 = Car("Toyota", "Corolla", 2023)
car2 = Car("BMW", "X5", 2022)

print(car1.info())  # Output: 2023 Toyota Corolla
print(car2.info())  # Output: 2022 BMW X5        

Inheritance and Polymorphism:

Inheritance:

Inheritance allows a new class (child class) to inherit properties and behavior from another class (parent or base class). It promotes code reuse and the creation of hierarchical relationships.

class ElectricCar(Car):
    def __init__(self, make, model, year, battery):
        super().__init__(make, model, year)
        self.battery = battery

    def electric_info(self):
        return f"{self.info()} with {self.battery} kWh battery"        

Here, ElectricCar is inheriting the Car class.

electric_car = ElectricCar("Tesla", "Model S", 2023, 100)
print(electric_car.electric_info())  # Output: 2023 Tesla Model S with 100 kWh battery        

Polymorphism:

Polymorphism allows objects to be treated as instances of their parent class, providing a way to use different classes through a uniform interface.

def get_car_info(car):
    print(car.info())

get_car_info(car1)           # Output: 2023 Toyota Corolla
get_car_info(electric_car)   # Output: 2023 Tesla Model S        

Both car1 and electric_car are treated as 'Cars' when passed to get_car_info(), even though electric_car is an instance of the ElectricCar class, demonstrating polymorphism.

Let's see some additional topics and best practices on Object-Oriented Programming concepts:

Encapsulation:

Encapsulation refers to the bundling of data (attributes) and methods that operate on the data within a class. It helps in controlling access to the inner workings of the object and protects the data from external interference.

Example:

class BankAccount:
    def __init__(self, account_number, balance):
        self.account_number = account_number
        self.__balance = balance  # Private attribute

    def get_balance(self):
        return self.__balance

    def deposit(self, amount):
        # Perform validation or other operations here
        self.__balance += amount

    def withdraw(self, amount):
        # Perform validation or other operations here
        if amount <= self.__balance:
            self.__balance -= amount
        else:
            print("Insufficient funds")        

Abstraction:

Abstraction focuses on hiding complex implementation details and showing only the necessary features of an object. It allows you to work at a higher level of understanding.

Example:

from abc import ABC, abstractmethod

class Shape(ABC):
    @abstractmethod
    def area(self):
        pass

class Circle(Shape):
    def __init__(self, radius):
        self.radius = radius

    def area(self):
        return 3.14 * self.radius * self.radius

class Rectangle(Shape):
    def __init__(self, width, height):
        self.width = width
        self.height = height

    def area(self):
        return self.width * self.height        

Method Overriding:

This allows a subclass to provide a specific implementation of a method that is already provided by its parent class.

Example:

class Animal:
    def sound(self):
        print("Some generic sound")

class Dog(Animal):
    def sound(self):
        print("Bark")

class Cat(Animal):
    def sound(self):
        print("Meow")        

Composition over Inheritance:

Sometimes, it's more advantageous to use composition (having an instance of another class within a class) rather than inheritance. It can lead to more flexible and maintainable code.

Example:

class Engine:
    def start(self):
        print("Engine started")

class Car:
    def __init__(self):
        self.engine = Engine()

    def start(self):
        self.engine.start()        

Understanding these concepts enhances your ability to design and implement more robust and efficient object-oriented systems. Each concept has its place and offers various advantages depending on the problem you're solving and the structure of your program. They allow for efficient code organization, re-usability, and readability.

To view or add a comment, sign in

More articles by Kundan S.

  • The Power of Data Analysis: Building Business Success 🚀

    The Power of Data Analysis: Building Business Success 🚀

    In today's digital age, data analysis has emerged as a pivotal force that can either propel a business to new heights…

  • Python Journey | Day 10

    Python Journey | Day 10

    Building practical projects is a great way to solidify your understanding of the language. Let's see some of the…

  • Python journey | Day 9

    Python journey | Day 9

    Day 9: Modules and Packages Module Importing:Learn how to use built-in and external modules. Creating Your…

  • Python journey | Day 8

    Python journey | Day 8

    Day 8 brings error handling which is a crucial aspect of programming to ensure your code can gracefully respond to…

    1 Comment
  • Python journey | Day 6

    Python journey | Day 6

    Python offers versatile functionalities for handling input and output operations, allowing interaction with users…

  • Python journey | Day 5

    Python journey | Day 5

    Lists and tuples are ordered collections in Python. Lists are mutable, allowing modifications, while tuples are…

  • Python journey | Day 4

    Python journey | Day 4

    Day 4: Functions Acknowledgement - Understanding the power of functions! From defining tasks to utilizing parameters…

  • Python journey | Day 3

    Python journey | Day 3

    Day 3 focusing on control structures, particularly conditional statements and loops, here's a structured plan to learn…

  • Python journey | Day 2

    Python journey | Day 2

    Here’s a rundown on Day 2 of learning about basic syntax, data types, variables, and operations in Python: 1. Print and…

  • Python journey | Day 1

    Python journey | Day 1

    Starting your Python journey is exciting. Here's a breakdown of Day 1: 1.

Insights from the community

Others also viewed

Explore topics