This is a series on Python and how to correctly use Python when coming from a background in another computer language. Because of this, this will not be a slow intro into programming and it will be assumed you have a preferred text editor and are smart enough to get Python running. You can download installers and packages from their official website found here. Basic knowledge of how to use Git and how to operate a computer is also preferred.

This series will assume you are familiar with some form of a computer language and basic programming paradigms. C/C++, JavaScript, and Go will be referred to most as they are my most familiar languages other than Python, but anyone with experience in really anything else should be able to follow along.

Also I know Python calls them methods but I use “methods” and “function” interchangeably.

Classes

There is something I omitted from the last article that you experienced object-oriented programmers and hackers would probably be in anguish without: classes. Classes are very engrained in Python’s nature. Creating a class can be done like so.

# This file is named "dogs.py"

class Dog:
    # this is a class variable and will be shared
    # with all instances of class 'Dog'
    genus = 'canine'

    # this function gets called
    # When you initialize a new instance
    # of the class 'Dog'
    # these variables are on a per instance
    # basis and will not be shared.
    def __init__(self, name, age):
        self.age = age
        self.name = name
        self.parts = {}
        self.furry = True
        self.hypoallergenic = False
    
    # this will be called when the 
    # class needs to be represented
    # such as when you try to print
    # an instance of it
    def __repr__(self):
        return f"({self.name}, {self.age})"

    def set_parts(self, tails=1, ears=2, paws=4):
        self.parts = { # this sets the instance variable
            "tails": tails,
            "ears": ears,
            "paws": paws
        }
        return self.parts # You can also return the value like a standard function

    def sheds(self):
        if self.furry and not self.hypoallergenic: # using the instance variables within logic
            return True
        return False

    @static_method # this is a method that can be 
    def bark():  # called without instantiating a class
        print('Bark Bark!')

if __name__=="__main__": # Only run if the file is being explicitly ran as a script.
    # Here is how to use the class
    murphy = Dog("Murphy", 7)
    murphy.bark()
    murphy.set_parts() # ticks all of the boxes for the default
    if murphy.sheds():
        print("You should buy a roomba.")

    champion = Dog("Champion", 2)
    champion.set_parts(1, 2, 3) # The dog from Parks and Rec only has 3 legs

    print(murphy)
    print(champion)

    # you can also call static methods like this
    Dog.bark()

Instance variables can be defined in functions with self.<var name>, and I prefer to define all the ones that I will be using in the __init__ method for my own organization. Class variables are defined outside of methods and are shared between all functions, even when changed. For example, If I were to change Murphy’s genus to ‘cat’ or something absurd, Champions’ genus would change as well. Also, classes can inherit other classes. Here is an example, assuming that the previous class-related code was imported previously.


from dogs import Dog 

class Labrador(Dog):
    def is_purebred(self):
        return True

if __name__=='__main__':
    # the class labrador would have the same 
    # methods, class vars and instance vars as
    # the previous dog class.
    marley = Labrador("Marley", 14)
    marley.bark()
    marley.set_parts()
    if marley.sheds():
        print("Labs shed a lot.")

    if marley.is_purebred():
        print("This dog is pure!")

In this example, I imported some of the previously written code. When you call the import statement, Python searches in a few places for your code. The places that it searches are called the PYTHONPATH, and your current directory is included. When you import another file in Python, the filename is omitted. Here is another import example:

import os

from dogs import Dog

name = os.getenv('DOG_NAME')
age = os.getenv('DOG_AGE')

dog = Dog(name, age)

In this import example, the standard library module os was used. This module gives access to operating system functions while remaining platform agnostic, so functions will work on any OS.

The order for imports, while not enforced, usually goes like this:

import standard_library

import pypi_module

import local_module

To install a PyPI module, run the command pip install <name>. Common modules include requests, a really simple HTTP REST request library, Flask, a popular and lightweight HTTP server framework, and Pillow, an image manipulation library. Many, many more exist, and can be found on PyPI.

Usually, when working with many Python packages, virtual environments are used. These make a project-level installation of packages, similar to how npm installs packages locally. See here for install instructions.

To use on Windows:

python -m venv env
.\env\Scripts\activate

To use on MacOS & Linux:

python3 -m venv env
source env/bin/activate

Then you can install packages as previously stated, but they will install to the virtual environment. To save all of the packages for later use on another system, run pip freeze > requirements.txt. To install packages from a fresh virtual environment:

python3 -m venv env
source env/bin/activate
pip install -r requirements.txt

All packages in requirements.txt will be installed to the virtual environment. This is equivalent Node’s package-lock.json file and should be committed to your source control.

This concludes Python For Programmers part 3.