Modules
A module is a file (script), containing definitions and statements. This can be any program that we write/wrote and hope to use that same code without copying and pasting the code into the new script. All we have to do is to import them.
Example
Consider the code below, this is taken from exercise 12 a (Functions).
# file name: area.py
# description:
#   A program that calculates and prints the area 
#   of a triangle taking the base and height as inputs
def calc_area():
    base = float(input("Enter base: "))
    height = float(input("Enter height: "))
    area = 0.5 * base * height
    result = f"The area of a triangle of base, {base}"
    result += f"and height, {height} is {area}"
    print(result)
Import a module
Importing a module is very simple really, all we need is the import keyword and the module name. The module name is the name of the file/script, without the suffix (extension), .py
import module_name
  
  
  Import area.py
To import the area.py, and make use of calc_area we have to import it.
import area
# think of this `import area` like an object with some
# properties and methods. The dot notation will work here. 
# It is for accessing the variables and functions in the
# imported object
area.calc_area()
# refer to this same code in `exercise 12 a (Functions)`
# we called the function similar to how we've done here
# just without the module name and this is because the 
# function is in the module
Import objects from a module
Let's assume that there is at least a function in the module and we want to make use of a particular one or all, using the from module import this_functionality ... annotation.
Add a function that calculates the perimeter of the triangle, calc_peri, to the area.py script and rename the module to triangle.py.
from module_name import object_name
Import a particular object
Our goal here is to import calc_area and calc_peri from the triangle module.
from triangle import calc_area, calc_peri
# call the calculate area function
calc_area()
# with this, we won't have to do, area.calc_area()
# call the calculate perimeter function
calc_peri()
Import all objects
Our goal here is to import all the objects in the module. This can be achieved by using * to imply all. With this, we have access to all the objects. Remember that import with * is not a good practice.
from triangle import *
# call the calculate area function
calc_area()
# call the calculate perimeter function
calc_peri()
Note
from module import object is almost similar to import module just that with the latter we have to do module.object to make use of the object.
visit Python doc to read on the built-in modules and packages
Math module
The math module contains some mathematical functions algebra, logarithm, trigonometry, some constants and others.
Let's make use of pi, e, gcd, exp, factorial, pow, sqrt, cos, sin.
pi and e are constants and the rest are functions.
We are going to import a lot of things from the math module thus to keep it structured we shall group them as tuples though it will work fine anyway.
More example
Note
We can do, from module import object as alias. This may allow the resolution of conflicting names. Say we have Square and Rectangle, with the same function names, we use the alias concept, as, to resolve it by giving them specific names.
# import employee script
from Employee import Employee as App
print("Employee")
me = App("John Matthew Doe", "Python Developer", 1200.00)
print(f"My name is {me.name} and i am a {me.job}.")
print(f"My salary is {me.salary}.")
print("When i work overtime, My salary for", end=" ") 
print(f"the month is {me.return_gross_pay(400)}")
Or
from triangle import calc_area as area, calc_peri as perimeter
# call area
area()
# call perimeter
perimeter()
We could have imported calc_area and calc_peri on different lines.
from triangle import calc_area as area
from triangle import calc_peri as perimeter
Practicals
- 
As a practice project, write a script, mathsmodule.pythat performs mathematical operations such as addition, subtraction, etc. Use a class and create atest.pyscript then import it there. Ourmoduleshould pass these test.
 Assume that the method names will include,add, subtr, mult, div, floor_div, pow, mod. Add comments and then create a new file,mathsmodule.md- this can be a.txtfile too. The documentation should have information about the developer, what the module is about, how to use the module, how and what to improve, how the methods work and how to use the methods, some errors we expect to occur, some constants that were used, etc. We hope this is becoming clear.- test add
- add(1,2) = 10
- add(1,-2) = -1
- add(1,2,3,4) = 10
- test subtr
- subtr(1,2) = -1
- subtr(1,-2) = 3
- test mult
- add(1,2) = 2
- add(1,-2) = -2
- add(1,2,4) = 8
- test div
- div(1,2) = 0.5
- div(1,-2) = -0.5
- div(5, 0) = None
- test floor_div
- floor_div(1,2) = 10
- floor_div(1,-2) = -1
- floor_div(1,2,3,4) = 10
- test pow
- pow(1,2) = 1
- pow(2,3) = 8
- pow(2,-2) = 0.25
- test mod
- mod(1,2) = 1
- mod(22,7) = 1
 
- For the second version of this program, let a method take 3 args, operator, first_operand, second_operand. Instead of calling any of the methods such as add, just call, - evaluatewith arguments such as- evaluate('+', 2, 5)to return 7. This should work even if the second and third arguments are in a form of strings such as- evaluate('+', '2', '5').
- For a third version, instead of the symbols, such as using, - +, use- addinstead. Thus- evaluate(+, 2, 5),- evaluate('+', '2', '5')and- evaluate('add', 2, 5)or- evaluate('add', '2', '5')works the same.
- Write a program that simulates the rolling of a dice. A fair dice has 6 sides numbered from 1 to 6. Take an integer input from the user as the number of times the dice must be rolled and this value must be greater than - 50.- printthe number of times a particular number was obtained when the dice was rolled. Make use of- randintfrom- randommodule.
Summary
- A module is a script that we can reuse in another code - look at the advantages of using a function in Excercise 12 a (Functions)
- use the importkeyword to bring in a module
- 
from module import *imports all the objects in the module
- 
from module import some_objectsimport these objects
- 
from module import object as objimports object given a new nameobjfrom module
 
 
              
 
    
Top comments (0)