Python : Classes
Classes are templates used to define the properties and methods of objects in code. They can describe the kinds of data that the class holds, and also how a programmer interacts with that data.
The usage of classes are a key element of object-oriented programming (OOP) where “class instances” are created to implement design principles such as inheritance and encapsulation.
Creating a Class
In Python, classes are defined using the class
keyword. The first letter of the name of the class is always capitalized. For instance, the first letter of the Home
class in the below example, i.e., ‘H’, is capitalized:
class Home:
# Class body starts here
Note: The example above would actually be invalid because class definitions cannot be empty. However, the pass
statement can be used as a placeholder to avoid errors:
class Home:
pass
In the class body, the self
keyword, followed by a period .
, can be used to call its methods and access its variables, as shown in the __init__()
dunder method below:
class Home: def __init__(self, rooms, stories):
# Setting instance variables
self.rooms = rooms
self.stories = stories
Class Instances
Objects can be created or instantiated from classes. These objects are known as class instances and are created by setting a variable equal to the class name followed by parentheses ()
:
my_home = Home()
Here, the instance name is my_home
, which derives from the Home
class. Calling this line implicitly calls the Home
class’s __init__()
method.
Attributes
Class attributes are variables that are defined outside of all methods and have the same value for every instance of the class. They also can be accessed via the class name rather than the instance name. Setting the variable via the class name will change it for all instances.
Note: Setting it via an instance name will break the connection for that instance.
class Bird:
# Class attribute
is_hungry = True
parakeet = Bird()
parrot = Bird()
print("Birds are hungry!")
print("Feeding birds...")
parakeet.is_hungry = False
parrot.is_hungry = False
print("Birds fed!")
This will output the following:
Birds are hungry!
Feeding birds...
Birds fed!
Methods
Methods are functions defined as part of a class. The first parameter for any class method, including dunder methods, is the actual object calling the method, usually called self
.
The following is a slight modification of the Bird
class from the previous section:
class Bird:
# Class attribute
is_hungry = True
def feed_bird(self, food):
if(self.is_hungry):
self.is_hungry = False
print(f"Feeding with {food}. Bird fed!")
else:
print("Bird already ate.")
sparrow = Bird()
sparrow.feed_bird('seeds')
sparrow.feed_bird('oats')
A feed_bird()
method is defined in the Bird
class body, accepting a food
parameter. Inside, an if..else
conditional prints a different message depending on whether or not the is_hungry
attribute is true. The following will be printed based on the example:
Feeding with seeds. Bird fed!
Bird already ate.
Static Methods
It is also possible to create a method that only applies to the class itself, not instances of the class. These can be distinguished with @classmethod
and @staticmethod
:
class Home:
name="Code Ninja"
rooms = 4
stories = 2
@staticmethod
def is_on_market(home):
if(home.name == ""):
return True
else:
return False
@classmethod
def paint_wall(self, color):
return f"Painting wall with the color {color}."
home = Home()
print(Home.is_on_market(home))
# Output: False
Example
The following example demonstrates an Employee
class defined in a file called employee.py
:
# employee.py
class Employee(object):
name = "Sam"
company = "ILoveCode Inc."
age = 30
is_on_vacation = True
def working(self, employee_name):
self.name = employee_name
print(f"{employee_name} is working")
Afterward, the Employee
class can be imported into other files where new instances and methods can be created. This makes the code efficient, reusable, and maintainable:
# other_file.py
from employee import Employee
def create_employee():
print("Employee is starting their job...")
employee1 = Employee()
employee1.name = "Blake"
employee1.working(employee1.name)
create_employee();
Running the code in other_file.py
will output the following:
Employee is starting their job...
Blake is working
Codebyte Example
Defined methods and variables can be accessed within the class definition. This is done with the self
keyword, followed by a period .
, and then followed by the method or variable. In the example below, the defined .getName()
method is used inside the .sayHi()
method:
# run this code to see the output
class Person:
def __init__(self, name):
self.name = name
def sayHi(self):
# Calls its method .getName()
print(f"Hi! My name is {self.getName()}.")
def getName(self):
# Accesses the name variable
return self.name
bob = Person("Bob")
bob.sayHi()