KEMBAR78
Python Function Basics | PDF | Parameter (Computer Programming) | Scope (Computer Science)
0% found this document useful (0 votes)
81 views8 pages

Python Function Basics

Python functions can be defined to perform reusable tasks. There are several types of functions including built-in functions, user-defined functions, and functions defined in modules. Functions allow arguments and parameters to be passed into them and can return values. Functions have local and global scopes that determine variable visibility. Functions can call themselves recursively and provide modularity for Python programs.

Uploaded by

chiragg642
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
81 views8 pages

Python Function Basics

Python functions can be defined to perform reusable tasks. There are several types of functions including built-in functions, user-defined functions, and functions defined in modules. Functions allow arguments and parameters to be passed into them and can return values. Functions have local and global scopes that determine variable visibility. Functions can call themselves recursively and provide modularity for Python programs.

Uploaded by

chiragg642
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 8

Python Functions

I. Types of function (built-in functions, user defined functions ,functions defined in module,)
II. Creating user defined function
III. Arguments and parameters
IV. Default parameters
V. Positional parameters
VI. Function returning value(s)
VII. Flow of execution
VIII. Scope of a variable (global scope, local scope)
IX. Recursion
X. Functions defined in module

A function is a block of organized, reusable code that is used to perform a single, related action. Functions provide better
modularity for your application and a high degree of code reusing. In Python, a function is a group of related statements that
performs a specific task. Functions help break our program into smaller and modular chunks. As our program grows larger and
larger, functions make it more organized and manageable. Furthermore, it avoids repetition and makes the code reusable.

I. Types of function

There are three types of functions in Python:

 Built-in functions (Library Function o PDFs), such as help() to ask for help, min() to get the minimum value, print() to
print an object etc.
 User-Defined Functions (UDFs), which are functions that users create to help them out.
 Functions defined in module.

II. Creating User Define Function

You can define functions to provide the required functionality. Here are simple rules to define a function in Python.

1. Function blocks begin with the keyword def followed by the function name and parentheses ( ( ) ).
2. Any input parameters or arguments should be placed within these parentheses. You can also define parameters
inside these parentheses.
3. The first statement of a function can be an optional statement - the documentation string of the function .
4. The code block within every function starts with a colon (:) and is indented.
5. The statement return [expression] exits a function, optionally passing back an expression to the caller. A return
statement with no arguments is the same as return None.

Syntax

1-2 def functionname( parameters ):

3 " documentation string "

4 code block

5 return [expression]

Example

def printme( str ):


"This prints a passed string into this function"

print str

return

III. Arguments and parameters

Information can be passed into functions as arguments.Arguments are specified after the function name, inside the parentheses.
You can add as many arguments as you want, just separate them with a comma.The following example has a function with one
argument (fname). When the function is called, we pass along a first name, which is used inside the function to print the full name:

Example

def my_function(fname):

print(fname + " Detail")

my_function("Emil")

my_function("Phone")

my_function("Address")

output

Emil Detail

Phone Detail

Address Detail

Parameters or Arguments

The terms parameter and argument can be used for the same thing: information that are passed into a function.

From a function's perspective: A parameter is the variable listed inside the parentheses in the function definition.

An argument is the value that is sent to the function when it is called.

Number of Arguments

By default, a function must be called with the correct number of arguments. Meaning that if your function expects 2 arguments, you
have to call the function with 2 arguments, not more, and not less.

Example

This function expects 2 arguments, and gets 2 arguments:

def my_function(a, b):

print(a+b)
my_function(12,14)

IV. Default Parameter Value

The following example shows how to use a default parameter value. If we call the function without argument, it uses the default
value:

Example

def my_function(country = "India"):

print("I am from " + country)

my_function()

my_function("Brazil")

V. Positional parameters

Arbitrary Arguments, *args

If you do not know how many arguments that will be passed into your function, add a * before the parameter name in the function
definition. This way the function will receive a tuple of arguments, and can access the items accordingly:

def my_function(*num):

print("The youngest child is " + kids[2])

my_function(2,4,6)

Keyword Arguments

You can also send arguments with the key = value syntax. This way the order of the arguments does not matter.

def my_function(child3, child2, child1):

print("The youngest child is " + child3)

my_function(child1 = "anil", child2 = "ankur", child3 = "anubhav")

Arbitrary Keyword Arguments, **kwargs

If you do not know how many keyword arguments that will be passed into your function, add two asterisk: ** before the parameter
name in the function definition.This way the function will receive a dictionary of arguments, and can access the items accordingly:

def my_function(**kid):

print("His last name is " + kid["lname"])


my_function(fname = "Amit", lname = "Agarwal")

Passing a List as an Argument

You can send any data types of argument to a function (string, number, list, dictionary etc.), and it will be treated as the same data
type inside the function.E.g. if you send a List as an argument, it will still be a List when it reaches the function:

def my_function(food):

for x in food:

print(x)

fruits = ["apple", "banana", "cherry"]

my_function(fruits)

VI. Function returning value(s)

To let a function return a value, use the return statement:

def my_function(x):

return 5 * x

print(my_function(3))

print(my_function(5))

print(my_function(9))

def plus(a,b):

sum = a + b

mul=a*b

return (sum, mul)

s, m = plus(3,4)

print(s)

print(m)
VII. Flow of execution

When you are working with functions it is really important to know the order in which statements are executed. This is called the
flow of execution .Execution always begins at the first statement of the program. Statements are executed one at a time, in order,
from top to bottom. Function definitions do not alter the flow of execution of the program, but remember that statements inside
the function are not executed until the function is called.

1 def pow(b, p):

2 y = b ** p

3 return y

5 def square(x):

6 a = pow(x, 2)

7 return a

9n=5

10 result = square(n)

11 print(result)

Ans: 1,5,9,10,5,6,1,2,3,6,7,10,11

VIII. Scope of a variable (Global scope, Local scope)

Local Scope

Whenever you define a variable within a function, its scope lies ONLY within the function. It is accessible from the point at which it is
defined until the end of the function and exists for as long as the function is executing (Source). Which means its value cannot be
changed or even accessed from outside the function. Let's take a simple example:

def print_number():

first_num = 1

# Print statement 1

print("The first number defined is: ", first_num)

print_number()

# Print statement 2
print("The first number defined is: ", first_num)

We were able to print the first_num variable by calling the function print_number() (# Print statement 1). But when trying to access
and then print the same variable from outside the function (# Print statement 2), it raised a NameError. This is because first_num is
"local" to the function - thus, it cannot be reached from outside the function body.

Global Scope

This is perhaps the easiest scope to understand. Whenever a variable is defined outside any function, it becomes a global variable,
and its scope is anywhere within the program. Which means it can be used by any function.

greeting = "Hello"

def greeting_world():

world = "World"

print(greeting, world)

def greeting_name(name):

print(greeting, name)

greeting_world()

greeting_name("Ankur")

IX. Recursion

Python also accepts function recursion, which means a defined function can call itself.Recursion is a common mathematical and
programming concept. It means that a function calls itself. This has the benefit of meaning that you can loop through data to reach a
result.

def recur_factorial(n):

if n == 1:

return n

else:

return n*recur_factorial(n-1)

num = 7

# check if the number is negative

if num < 0:
print("Sorry, factorial does not exist for negative numbers")

elif num == 0:

print("The factorial of 0 is 1")

else:

print("The factorial of", num, "is", recur_factorial(num))

X. Functions defined in module

When you need to write longer programs you start writing scripts. As your program grows more in the size you may want to split it
into several files for easier maintenance as well as reusability of the code. The solution to this is Modules. You can define your most
used functions in a module and import it, instead of copying their definitions into different programs. A module can be imported by
another program to make use of its functionality. This is how you can use the Python standard library as well.

Simply put, a module is a file consisting of Python code. It can define functions, classes, and variables, and can also include runnable
code. Any Python file can be referenced as a module. There are various methods of writing modules, but the simplest way is to
create a file with a .py extension which contains functions and variables.

Writing a module is just like writing any other Python file. Let's start by writing a function to add/subtract two numbers in a file
calculation.py.

def add(x,y):

return (x+y)

def sub(x,y):

return (x-y)

If you try to execute this script on the command line, nothing will happen because you have not instructed the program to do
anything. Create another python script in the same directory with name module_test.py and write following code into it.

import calculation #Importing calculation module

print(calculation.add(1,2)) #Calling function defined in add module.

If you execute module_test.py, you will see "3" as output. When the interpreter came across the import statement, it imported the
calculation module in your code and then by using the dot operator, you were able to access the add() function.

More on Import Statements

Tere are more ways to import modules:

 from .. import statement


 from .. import * statement
 renaming the imported module

from .. import statement


The from..import statement allows you to import specific functions/variables from a module instead of importing everything. In the
previous example, when you imported calculation into module_test.py, both the add() and sub() functions were imported. But what
if you only needed the add() function in your code?

Here is an example to illustrate the use of from..import

from calculation import add

print(add(1,2))

In above example, only the add() function is imported and used. Notice the use of add()? You can now access it directly without
using the module name. You can import multiple attributes as well, separating them with a comma in the import statement. Take a
look at the following example:

from calculation import add,sub

from .. import * statement

You can import all attributes of a module using this statement. This will make all attributes of imported module visible in your code.

Here is an example to illustrate the use of from .. import *:

from calculation import *

print(add(1,2))

print(sub(3,2))

Note that in the professional world, you should avoid using from..import and from..import*, as it makes your code less readable.

Renaming the imported module

You can rename the module you are importing, which can be useful in cases when you want to give a more meaningful name to the
module or the module name is too large to use repeatedly. You can use the as keyword to rename it. The following example explains
how to use it in your program.

import calculation as cal

print(cal.add(1,2))

You saved yourself some typing time by renaming calculation as cal.

Note that you now can't use calculation.add(1,2) anymore, as calculation is no longer recognized in your program.

You might also like