函数

定义


##简单定义
def greet_user():
    """   heelo """
    print("hello  llll!!")
    
greet_user()    


##向函数传递信息

def greet_user(username):
    """ jjjjj """
    print("Hello, " + username.title() + "!")

greet_user('jesse')



形参和实参

以上示例,username 为形参,值'jesse'是一个实参,实参是调用函数时传递给函数的信息,这个值被存储在形参username中。

传递实参

函数定义中可能包含多个形参,因此函数调用中也可能包含多个实参。
向函数传递实参的方式很多,可使用位置实参,这要求实参的顺序与形参的顺序相同;也可使用关键字实参,其
中每个实参都由变量名和值组成;还可使用列表和字典。

位置实参

调用函数时,Python必须将函数调用中的每个实参都关联到函数定义中的一个形参。为此,最简单的关联方式是基于实参的顺序。这种关联方式被称为位置实参

def describe_pet(animal_type, pet_name):
    """kkkk"""
    print("
I have a " + animal_type + ".")
    print("My " + animal_type + "'s name is " + pet_name.title() + ".")

describe_pet('hamster', 'harry') 

可以调用函数多次
位置实参的顺序很重要

关键字实参

关键字实参是传递给函数的名称—值对

def describe_pet(animal_type, pet_name):
    print("
I have a " + animal_type + ".")
    print("My " + animal_type + "'s name is " + pet_name.title() + ".")

describe_pet(animal_type='hamster', pet_name='harry') 

默认值

可给每个形参指定默认值。在调用函数中给形参提供了实参时,Python将使用指定的实参值;否则,将使用形参的默认值。因此,给形参指定默认值后,可在函数调用中省略相应的实参。使用默认值可简化函数调用,还可清楚地指出函数的典型用法。

def describe_pet(pet_name, animal_type='dog'):
 """显示宠物的信息"""
  print("
I have a " + animal_type + ".")
  print("My " + animal_type + "'s name is " + pet_name.title() + ".") 

describe_pet(pet_name='willie') 
#或
describe_pet(pet_name='harry', animal_type='hamster') 


##可能的函数调用
# 一条名为Willie的小狗
describe_pet('willie')
describe_pet(pet_name='willie')
# 一只名为Harry的仓鼠
describe_pet('harry', 'hamster')
describe_pet(pet_name='harry', animal_type='hamster')
describe_pet(animal_type='hamster', pet_name='harry') 

避免实参错误

提供的实参多于或少于函数完成其工作所需的信息时,将出现实参不匹配错误

返回值

函数返回的值被称为返回值。在函数中,可使用return语句将值返回到调用函数的代码行

def get_formatted_name(first_name, last_name):
    full_name = first_name + ' ' + last_name
    return full_name.title()

musician = get_formatted_name('jimi', 'hendrix')
print(musician) 

实参变成可选的

def get_formatted_name(first_name, last_name, middle_name=''):
 """返回整洁的姓名"""
 if middle_name:
    full_name = first_name + ' ' + middle_name + ' ' + last_name
 else:
    full_name = first_name + ' ' + last_name
 return full_name.title()

musician = get_formatted_name('jimi', 'hendrix')
print(musician)
musician = get_formatted_name('john', 'hooker', 'lee')
print(musician) 

返回字典

def bulild(fistname,secondname):
    tt = {'kk':fistname,'ll':secondname}
    return  tt

dd = bulild("sss","ttt")
print(dd)

传递列表

将列表传递给函数后,函数就能直接访问其内容

def greet_users(names):
 """向列表中的每位用户都发出简单的问候"""
 for name in names:
    msg = "Hello, " + name.title() + "!"
    print(msg)
    
    
usernames = ['hannah', 'ty', 'margot']
greet_users(usernames) 

传递任意数量的实参

def make_pizza(*toppings):
 """打印顾客点的所有配料"""
 print(toppings)

make_pizza('pepperoni')
make_pizza('mushrooms', 'green peppers', 'extra cheese') 

函数存储在模块

函数的优点之一是,使用它们可将代码块与主程序分离
将函数存储在被称为模块的独立文件中,再将模块导入到主程序中。import语句允许在当前运行的程序文件中使用模块中的代码

通过将函数存储在独立的文件中,可隐藏程序代码的细节,将重点放在程序的高层逻辑上。这还能让你在众多不同的程序中重用函数。将函数存储在独立文件中后,可与其他程序员共享这些文件而不是整个程序。知道如何导入函数还能让你使用其他程序员编写的函数库

模块是扩展名为.py的文件,包含要导入到程序中的代码
使用如下语法调用其中任何一个函数

module_name.function_name()

导入特定函数

from module_name import function_name

通过用逗号分隔函数名,可根据需要从模块中导入任意数量的函数
from module_name import function_0, function_1, function_2

使用 as 给函数指定别名

如果要导入的函数的名称可能与程序中现有的名称冲突,或者函数的名称太长,可指定简短而独一无二的别名——函数的另一个名称,类似于外号

指定别名的通用语法如下:
from module_name import function_name as fn

导入模块中的所有函数

使用星号(*)运算符可让Python导入模块中的所有函数
from xxx import *

函数编写指南

1,给函数指定描述性名称,且只在其中使用小写字母和下划线,描述性名称可帮助你和别人明白代码想要做什么。给模块命名时也应遵循上述约定
2,每个函数都应包含简要地阐述其功能的注释,该注释应紧跟在函数定义后面,并采用文档字符串格式
3,给形参指定默认值时,等号两边不要有空格

def function_name(parameter_0, parameter_1='default value') 
对于函数调用中的关键字实参,也应遵循这种约定:
function_name(value_0, parameter_1='value') 
原文地址:https://www.cnblogs.com/g2thend/p/11746434.html