What is a module in Python?
What is a python module?
Imagine that modules work like instructions to make a pie. Instead of trying to figure out what the steps are to create your pie, you follow the instructions.
Modules work in the same way. They are building blocks for adding functionality to your code, so you donât need to continually redo everything.
A Python module contains statements and definitions. A file like sample.py can be a module named sample, and can be imported. Modules in Python can contain both executable statements and functions.
Value and purpose of modules
Modules come from modular programming. This means that the functionality of code is broken down into parts or blocks of code. These parts or blocks have great advantages which are:
- scope
- reusability
- simplicity
Everything in Python is an object, so the names that you use for functions, variables, and so on become important.
Scope
Scoping means that modules create a separate namespace. Two different modules can have functions with the same name, and importing a module makes this a part of the global space in the code being executed.
Reusability
The most important advantage!
When you write a piece of code, modules help you avoid the need to write all the functionalities that you may need. Duplication of code, duplication of efforts uses more computer memory and itâs less efficient.
Simplicity
When modules have a little dependency on each other, it helps achieve simplicity. Each module is built with a simple purpose in mind. Modules are defined by their usage.
You can also use a regular expression or RE module for managing regular expressions.
Simplicity also helps in avoiding interdependency among these modules.
If youâre working on data visualization, import of a single module like Matplotlib is sufficient for visualizing your data.
Differences of module
The main difference between these modules is the way the modules are accessed.
Some modules are already built into the standard Python library.
When you use a statement like Import math in your Python code for example, the interpreter first tries to find a built-in modules.
NOTE
The first important thing to know is that modules are imported only once during execution.
Since modules are built to help you, stand-alone modules hold all the functions, but will most likely not contain functions that execute without calling. Itâs only when the user executes the different functions inside that module that they will find the utility of those functions in the code.
NOTE
The module is normally defined at the beginning of the code, but you can define it at any point in the code. Since code execution in Python is serial, you must import the module first before you execute any function inside of it.
Modules can also be executed from within the function. This means that the code inside that module can only be used once the function is executed.
Accessing modules
WARNING
Any python file can be a module.
The modules are searched by the interpreter and the following sequence:
- Current directory path
- built-in module directory
- Python path environment variable with a list of directories
- It investigates the installation dependent default direcotry
Examples
The print function returns all the possible locations that the interpreter is going to look for when searching for modules, including the current working directory.
TIP
ctrl + click on the
calendar
takes you to thecalendar.py
file. Note how the calendar module itself has imported a few other modules, and other than that, it contains all the functionalities.
The import statement
Every python file, which means any file with a .py
extension containing a script is effectively a module. The checkimports
file I am currently creating, is therefore a module for some of the files.
The code that you are working with is generally called the main module. In this case checkimports
is the main module present in the current working directory. Also called the scope of the project.
INFO
Python has a library of standard modules called built in modules. These modules are directly built into the python interpreter and donât have to be installed separately.
The list of built in modules can be found in the python standard library. You can think of packages as the structuring of python modules as a collection.
NOTE
Special files called
init.py
files are required for python to treat directories containing the file as packages.
Python has a rich collection of community built packages that I could find on the python package index, or pyPI.
INFO
pip
orpip3
is the default package installer for python, and helps with the installation of packages from pyPI.
Package installation
pip install <Package Name>
to install packages from pyPI index.
Modules from another directory
Writing import statements
Most of the modules that you will come across, especially the built-in modules, will not have any print statements, and they will simply be loaded by the interpreter.
Instead of importing the entire math module as we did above, there is a better way to handle this by directly importing the square root function inside the scope of the project.
This will prevent overloading the interpreter by importing the entire math module.
Alias
Alias for Functions in a module
Importing multiple functions
Importing all functions inside a module
Importing packages is very similar to importing modules in Python. Just like you can have imported functions, you could also import variables and classes from a given module.
Namespacing and scoping
INFO
The official Python documentation defines namespace as mapping from names to objects, and scope is the textual region of a Python program where the namespace is directly accessible.
At this point, the dictionary with its key value pairs serves as the ideal data structure for the mapping of names and objects.
You can view the same module as a place where Python creates a module object. A module object contains the names of different attributes defined inside it.
In this way, modules are a type of namespace. Namespaces and scopes can become very confusing very quickly, and so it is important to get as much practice of scopes as possible to ensure a standard of quality.
There are four main types of that can be defined in Python:
- local
- enclosed
- global
- built-in
[[3.Functions and Data Structures#[Function and variable scope](https //www.coursera.org/learn/programming-in-python/supplement/PmZPi/function-and-variable-scope)]]
Scope Resolution
The practice of trying to determine in which scope a certain variable belongs is known as scope resolution.
Scope resolution follows what is known commonly as the LEGB rule.
Local
This is where the first search for a variable is in the local scope.
Enclosed
This is defined inside an enclosing or nested functions.
Global
Global is defined at the uppermost level or simply outside functions.
Built-in
Which is the keywords present in the built-in module.
NOTE
In simpler terms, a variable declared inside a function is local, and the ones outside the scope of any function generally are global.
INFO
The id function is used here in the print statements, which returns the identity of the objects.
You can make some observations from the output.
- The id for the global variable alpha remains same as defined after the code is completely executed.
- The id for the local variable beta inside the function b remains unchanged before and after the execution of nested function c.
- The id for Gamma is assigned only within the scope of the nested function.
- The id for all three variables is different even if they all have the same variable name.
Variables in Python are implicitly declared when you define them. That means, unlike other programming languages, there is no special declaration made in Python for the variable which specifies its datatype.
What it also implies is that a given variable is local, not global when it is declared unless stated otherwise.
This contrasts with most other programming languages where variables are global by default.
When a variable is declared in a global space, it is also local to that space.
While global variables are acceptable, theyâre discouraged for a number of reasons. When you are working with production code, the project structure can get complex, and working with global variables can be hard to diagnose which lead to what is called the spaghetti code.
Other paradigms such as access modifiers, concurrency, and memory allocation are better handled with local variables.
Global & None-Global
There are two key words that can be used to change the scope of the variables, global and non-local.
The global keyword helps us access the global variables from within the function.
Nonlocal is a special type of scope defined in Python that is used within the nested functions only in the condition that it has been defined earlier in the enclosed functions.
reload() function
The reload function reloads an imported module in Python. The only precondition is that the argument passed to it must be a module that has already been successfully imported within the program.
The import is done just once, even if you write import module
multiple times.
Now if you add or delete files in your directory, you will see the changes.
Module Use-cases
So far you have learned about modules, packages and libraries in the context of using modules in Python. The third-party packages in Python are in most cases open-source, free and available for a wide variety of domains. These resources extend the functionality of Python programs beyond the built-in modules and are one of the main reasons why Python is popular today.
Before you learn how to install and use these packages, letâs briefly go through the difference between a module, a package and a library.
Modules, libraries and packages
Modules and packages can easily be confused because of their similarities, but there are a few differences. Modules are similar to files, while packages are like directories that contain different files. Modules are generally written in a single file, but thatâs more of a practice than a definition.
Packages are essentially a type of module. Any module that contains the path definition is a package. Packages, when viewed as a directory, can contain sub-packages and other modules. Modules, on the other hand, can contain classes, functions and data members just like any other Python file.
Library is a term thatâs used interchangeably with imported packages. But in general practice, it refers to a collection of packages.
Despite the differences between modules, packages and libraries, you can import any of them using import statements.
Third-party package add-ons of Python can be found in the Python Package Index. To install packages that arenât a part of the standard library programmers use âpipâ (package installer for Python). It is installed with Python by default. To use pip, you need to be familiar with either the terminal if youâre using a Mac or the command line interface if youâre using Windows.
Alternatively, you can also use the terminal window present inside your IDE. When you are using the command line or terminal, you must make sure that you are installing packages in the same Python interpreter that you are working with inside your IDE.
While pip usually comes installed with Python by default it might be necessary to check the status of pip installation. If youâre using a Mac, run the following command in the terminal:
python -m ensurepip --upgrade
If youâre using Windows, you run the following command:
py -m ensurepip --upgrade
Once you verify its installation, you can install packages using pip on your machine.
The standard format for using pip command on MacOS is:
python3 -m pip install "SomeProject"
py -m pip install "SomeProject"
Letâs examine an example. If you want to install a third-party package such as ârequestsâ, you run the following command on a Mac:
python3 -m pip install requests
For Windows youâd run this one:
py -m pip install requests
Note: Package names as well as the command line or terminal are case-sensitive.
Once you have installed the package, you will be able to use the package directly inside your Python code. This is a one-time installation and the package will be present as a part of your Python interpreter until you choose to uninstall it.
The packages that you can install often have a number of classes, functions, sub-packages and members. These can be understood by using the package and finding examples that other programmers have posted on different websites. This will give you a better understanding of what functionality within that package needs more attention than others.
Additionally, it is also a good practice to look up the documentation of the packages. In some cases, you can use the Python Package Index pypi website. In other cases, the packages are built and maintained by open-source communities and you can find their information on a standalone website created for it or on a version control system such as GitHub. Documentation in most of the popular Python libraries today is pretty elaborate and should have good examples to get you started.
Sub-packages
If we are to assume that packages are similar to a folder or directory in our operating system, then the package can also contain other directories. Packages, both built-in and user-defined, can contain other folders within them that need to be accessed. These are named sub-packages. You use dot-notation to access sub-packages within a package you have imported. For example, in a package such as matplotlib, the contents that are used most commonly are present inside the subpackage pyplot. Pyplot eventually may consist of various functions and attributes.
The code for importing a sub-package is:
import matplotlib.pyplot
To make it even more convenient, it is often imported using an alias. So more commonly, you will come across code such as:
import matplotlib.pyplot as plt
You could use any other word as an alias instead of plt, but it is a common convention.
You can explore the directory structure of such packages usually by searching for the module index of that package.
Additional resources
Learn more Here is a list of resources that may be helpful as you continue your learning journey.
How To Import Modules in Python 3 (Digital Ocean)
Python Modules (Programiz)
Python Packages (Real Python)
ModuleImportNamespacescopePython
Previous one â 7.Object Oriented Programming | Next one â 9.Popular Packages, Libraries and Frameworks