OOP & PYTHON
OOP & PYTHON
Python has been an object-oriented language since the time it existed. Due to this, creating
and using classes and objects are downright easy. This chapter helps you become an expert
in using Python's object-oriented programming support.
Class variable − A variable that is shared by all instances of a class. Class variables
are defined within a class but outside any of the class's methods. Class variables are
not used as frequently as instance variables are.
Data member − A class variable or instance variable that holds data associated with
a class and its objects.
Instance variable − A variable that is defined inside a method and belongs only to
the current instance of a class.
Inheritance − The transfer of the characteristics of a class to other classes that are
derived from it.
Instance − An individual object of a certain class. An object obj that belongs to a class
Circle, for example, is an instance of the class Circle.
Object − A unique instance of a data structure that is defined by its class. An object
comprises both data members (class variables and instance variables) and methods.
Creating Classes
The class statement creates a new class definition. The name of the class immediately
follows the keyword class followed by a colon as follows −
class ClassName:
class_suite
The class has a documentation string, which can be accessed via ClassName.__doc__.
1
The class_suite consists of all the component statements defining class members,
data attributes and functions.
Example
Following is an example of a simple Python class −
class Employee:
empCount = 0
self.name = name
self.salary = salary
Employee.empCount += 1
def displayCount(self):
def displayEmployee(self):
The variable empCount is a class variable whose value is shared among all the
instances of a in this class. This can be accessed as Employee.empCount from inside
the class or outside the class.
The first method __init__() is a special method, which is called class constructor or
initialization method that Python calls when you create a new instance of this class.
You declare other class methods like normal functions with the exception that the first
argument to each method is self. Python adds the self argument to the list for you; you
do not need to include it when you call the methods.
2
Accessing Attributes
You access the object's attributes using the dot operator with object. Class variable would be
accessed using class name as follows −
emp1.displayEmployee()
emp2.displayEmployee()
#!/usr/bin/python3
class Employee:
empCount = 0
self.name = name
self.salary = salary
Employee.empCount += 1
def displayCount(self):
def displayEmployee(self):
emp1.displayEmployee()
emp2.displayEmployee()
3
Instead of using the normal statements to access attributes, you can use the following
functions
__module__ − Module name in which the class is defined. This attribute is "__main__"
in interactive mode.
__bases__ − A possibly empty tuple containing the base classes, in the order of their
occurrence in the base class list.
For the above class let us try to access all these attributes −
#!/usr/bin/python3
class Employee:
empCount = 0
self.name = name
self.salary = salary
Employee.empCount += 1
def displayCount(self):
4
def displayEmployee(self):
Python's garbage collector runs during program execution and is triggered when an object's
reference count reaches zero. An object's reference count changes as the number of aliases
that point to it changes.
5
del a # Decrease ref. count of <40>
You normally will not notice when the garbage collector destroys an orphaned instance and
reclaims its space. However, a class can implement the special method __del__(), called a
destructor, that is invoked when the instance is about to be destroyed. This method might be
used to clean up any non-memory resources used by an instance.
Example
This __del__() destructor prints the class name of an instance that is about to be destroyed −
#!/usr/bin/python3
class Point:
self.x = x
self.y = y
def __del__(self):
class_name = self.__class__.__name__
pt1 = Point()
pt2 = pt1
pt3 = pt1
del pt1
del pt2
del pt3
Note − Ideally, you should define your classes in a separate file, then you should import
them in your main program file using import statement.
In the above example, assuming definition of a Point class is contained in point.py and there
is no other executable code in it.
6
#!/usr/bin/python3
import point
p1 = point.Point()
Class Inheritance
Instead of starting from a scratch, you can create a class by deriving it from a pre-existing
class by listing the parent class in parentheses after the new class name.
The child class inherits the attributes of its parent class, and you can use those attributes as
if they were defined in the child class. A child class can also override data members and
methods from the parent.
Syntax
Derived classes are declared much like their parent class; however, a list of base classes to
inherit from is given after the class name −
class_suite
Example
#!/usr/bin/python3
parentAttr = 100
def __init__(self):
def parentMethod(self):
Parent.parentAttr = attr
def getAttr(self):
def __init__(self):
def childMethod(self):
7
c = Child() # instance of child
In a similar way, you can drive a class from multiple parent classes as follows −
.....
.....
.....
You can use issubclass() or isinstance() functions to check a relationships of two classes and
instances.
The issubclass(sub, sup) boolean function returns True, if the given subclass sub is
indeed a subclass of the superclass sup.
Overriding Methods
You can always override your parent class methods. One reason for overriding parent's
methods is that you may want special or different functionality in your subclass.
Example
#!/usr/bin/python3
def myMethod(self):
def myMethod(self):
8
print ('Calling child method')
__del__( self )
__repr__( self )
__str__( self )
__cmp__ ( self, x )
5 Object comparison
Overloading Operators
9
Suppose you have created a Vector class to represent two-dimensional vectors. What
happens when you use the plus operator to add them? Most likely Python will yell at you.
You could, however, define the __add__ method in your class to perform vector addition and
then the plus operator would behave as per expectation −
Example
#!/usr/bin/python3
class Vector:
def __init__(self, a, b):
self.a = a
self.b = b
def __str__(self):
return 'Vector (%d, %d)' % (self.a, self.b)
def __add__(self,other):
return Vector(self.a + other.a, self.b + other.b)
v1 = Vector(2,10)
v2 = Vector(5,-2)
print (v1 + v2)
Vector(7,8)
Data Hiding
An object's attributes may or may not be visible outside the class definition. You need to
name attributes with a double underscore prefix, and those attributes then will not be
directly visible to outsiders.
Example
#!/usr/bin/python3
class JustCounter:
__secretCount = 0
def count(self):
self.__secretCount += 1
print (self.__secretCount)
counter = JustCounter()
counter.count()
counter.count()
print (counter.__secretCount)
1
2
Traceback (most recent call last):
File "test.py", line 12, in <module>
print counter.__secretCount
AttributeError: JustCounter instance has no attribute '__secretCount'
10