一个简单的函数

先看一个简单的函数

def say_hello():
'''打印hello'''
print("Hello!")
say_hello()
#运行结果
Hello!

def为函数的关键字,say_hello为你定义的函数的名称,还可能在括号内指出函数为完成其任务需要什么样的信息,即便括号是空的,也是必不可少的,最后以冒号结尾。

向函数传递信息

def say_hello(name):
'''打印hello'''
print("Hello! " + name)
say_hello('Frank')
#运行结果
Hello! Frank

这里在括号里面加了一个变量name,然后将'Frank'传递给了name,输出。

实参和形参

在函数say_hello的定义中,变量name是一个形参——函数完成其工作所需的一项信息。在代码say_hello('Frank')中,其'Frank'就是一个实参,实参是调用函数时传递给函数的信息。

传递实参

位置实参

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

def introduce(name,age):
'''自我介绍'''
print("Hello! my name is " + name +" !" + "I'am " + age + " years old !")
introduce('Frank','')
#运行结果
Hello! my name is Frank !I'am 18 years old !

关键字实参

可以直接将形参和实参关联起来,这样就不必要在意顺序了。

def introduce(name,age):
'''自我介绍'''
print("Hello! my name is " + name +" !" + "I'am " + age + " years old !")
introduce(age='',name='Candy')
#运行结果
Hello! my name is Candy !I'am 18 years old !

默认值

可以给函数的形参指定一个默认值,当你给形参重新指定值的时候,会覆盖默认值。

def introduce(name,age=''):
'''自我介绍'''
print("Hello! my name is " + name +" !" + "I'am " + age + " years old !")
introduce(name='Candy')
introduce(age='',name='Frank')
#运行结果
Hello! my name is Candy !I'am 20 years old !
Hello! my name is Frank !I'am 23 years old !

返回简单值

函数并非总是直接显示输出,相反,它可以处理一些数据,并返回一个或一组值。函数返回的值被称为返回值。

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)
#运行结果
Jimi Hendrix

让实参变为可选的

有的时候,我们不需要每个形参都有实参,但是没有实参会导致输出出错,可以看一下下面的例子:

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('jimi','hendrix','dork')
print(musician)
#运行结果
Jimi Hendrix
Jimi Dork Hendrix

看上面的例子,并非所有的人都中间名,所有我们在指定实参的时候,middle_name不一定要有,这里我们用''空字符串来指定middle_name的默认值(空字符串为False),再用if判断用那种full_name的格式输出。

返回字典

def build_person(first_name,last_name,age=''):
'''返回一个值,其中包含一个人的信息'''
person = {"first":first_name,"last":last_name}
if age:
person['age'] = age
return(person)
musician = build_person('jimi','hendrix','')
print(musician)
#运行结果
{'first': 'jimi', 'last': 'hendrix', 'age': ''}

函数可返回任何类型的值,包括列表和字典等较复杂的数据结构。

结合使用while循环和函数

def get_formatted_name(first_name,last_name):
'''返回整洁的姓名'''
full_name = first_name + " " + last_name
return full_name.title()
while True:
f_name = input("Please input your first name:")
l_name = input("Please input your last name:")
name = get_formatted_name(f_name,l_name)
print("hello! " + name)
#运行结果
Please input your first name:bin
Please input your last name:liu
hello! Bin Liu
Please input your first name:

函数括号里面也可以是被赋值的变量名。

传递列表

可以将一个列表传递给形参

def greet_users(names):
'''遍历列表,打招呼'''
for name in names:
print("Hello, " + name + '!')
usernames = ["Frank","May","Caroline"]
greet_users(usernames)
#运行结果
Hello, Frank!
Hello, May!
Hello, Caroline!

在函数中修改列表

def  print_models(upprint,completed):
'''弹出已打印的给完成的列表,并打印'''
while upprint:
current = upprint.pop()
print("print:",current)
completed.append(current)
def show_models(completed):
'''显示已打印的'''
print("The following models have been print:")
for c in completed:
print(c)
upprint = ["apple","book","shirt"]
completed = []
print_models(upprint,completed)
show_models(completed)
#运行结果
print: shirt
print: book
print: apple
The following models have been print:
shirt
book
apple

在这个例子中,函数执行结束后,upprint列表就空了,为了解决这个问题,可向函数传递列表的副本而不是原件,这样函数所做的任何修改都只影响副本,而不会影响原件。

def  print_models(upprint[:],completed):
切片表示法[:],创建列表副本。
虽然向函数传递列表的副本可以保留原始的列表的内容,但除非有充分的理由需要传递副本,否则还是应该讲原始数据传递给函数,因为让函数使用现成列表可以避免花时间和内存创建副本,从而提高效率,在处理大型列表时尤其如此。

传递任意数量的实参

有时候,你预先不知道函数需要接受多少个实参,好在Python允许函数从调用语句中收集任意数量的实参:
def make_pizza(*toppings):
'''概述要制作的pizza'''
print("\nMaking a pizza with the following toppings:")
for topping in toppings:
print("--",topping)
make_pizza('pepperoni')
make_pizza('mushrooms','grenn peppers','extra cheese')
#运行结果
Making a pizza with the following toppings:
-- pepperoni
Making a pizza with the following toppings:
-- mushrooms
-- grenn peppers
-- extra cheese

形参名*toppings的星号让Python创建一个名为toppings的空元祖,并将收到的所有值都封装想到这个元祖中。

结合使用位置实参和任意数量实参

如果要让函数接受不同类型的实参,必须在函数定义中将接纳任意数量实参的形参放在最后。Python会先匹配实参和关键字实参,再将余下的实参都收集到最后一个形参中。

def make_pizza(size,*toppings):
'''概述要制作的pizza'''
print("\nMaking a " + str(size) + "-inch pizza with the following toppings:")
for topping in toppings:
print("--",topping)
make_pizza(16,'pepperoni')
make_pizza(12,'mushrooms','grenn peppers','extra cheese')
#运行结果
Making a 16-inch pizza with the following toppings:
-- pepperoni
Making a 12-inch pizza with the following toppings:
-- mushrooms
-- grenn peppers
-- extra cheese

使用任意数量的关键字实参

在下面的例子中,函数build_profile()接收名和姓,同时还接收任意数量的关键字和实参:
def build_profile(first_name,last_name,**info):
'''创建一个字典,其中包含我们知道的有关用户的一切'''
profile={}
profile["first_name"]=first_name
profile["last_name"]=last_name
for k,v in info.items():
profile[k]=v
return profile
user_profile = build_profile("bin","liu",location="princeton",field="physics")
print(user_profile)
#运行结果
{'first_name': 'bin', 'last_name': 'liu', 'location': 'princeton', 'field': 'physics'}

将函数存储在模块中

导入整个模块
例子:先创建一个打印方式make_pizza.py
#pizza打印方式模块
def make_pizza1(size,*toppings):
'''概述要制作的pizza'''
print("\n Making a " + str(size) +
"-inch pizza with the following toppings:")
for topping in toppings:
print("----" + topping)
def make_pizza2(size,*toppings):
'''概述要制作的pizza'''
print("\nsize:",size)
print("toppings:")
for topping in toppings:
print("====",topping)

在同一目录下创建:pizza.py

#pizza
import make_pizza
make_pizza.make_pizza1(16,'pepperoni','mushrooms')
make_pizza.make_pizza2(16,'pepperoni','mushrooms')

运行结果:

 Making a 16-inch pizza with the following toppings:
----pepperoni
----mushrooms
size: 16
toppings:
==== pepperoni
==== mushrooms
要调用被导入的模块中的函数,可指定导入模块的名称make_pizza和函数名make_pizza1(),并用句点来分割他们。
这就是一种导入方法,只需编写一条import语句并在其中指定模块名,就可以在程序中使用该模块中的所有函数:module_name.function_name()
 

导入特定的函数

语法如下:
from module_name import function_name
通过用逗号分隔函数名,可根据需要从模块中导入任意数量的函数
from module_name import function_0,  function1, function2 
若使用这种语法,调用函数的时候就不需要使用句点了
#pizza打印方式模块   文件make_pizza.py
def make_pizza1(size,*toppings):
'''概述要制作的pizza'''
print("\n Making a " + str(size) +
"-inch pizza with the following toppings:")
for topping in toppings:
print("----" + topping)
def make_pizza2(size,*toppings):
'''概述要制作的pizza'''
print("\nsize:",size)
print("toppings:")
for topping in toppings:
print("====",topping)
#pizza 文件pizza.py
from make_pizza import make_pizza1,make_pizza2
make_pizza1(16,'pepperoni','mushrooms')
make_pizza2(16,'pepperoni','mushrooms')
#运行结果
Making a 16-inch pizza with the following toppings:
----pepperoni
----mushrooms
size: 16
toppings:
==== pepperoni
==== mushrooms

使用as给函数定义别名

#pizza
from make_pizza import make_pizza1 as pz1,make_pizza2 as pz2
pz1(16,'pepperoni','mushrooms')
pz2(16,'pepperoni','mushrooms')
#运行结果
Making a 16-inch pizza with the following toppings:
----pepperoni
----mushrooms
size: 16
toppings:
==== pepperoni
==== mushrooms

语法:from module_name import function_name as fn

 

使用as给模块定义别名

#pizza
import make_pizza as pz
pz.make_pizza1(16,'pepperoni','mushrooms')
pz.make_pizza2(16,'pepperoni','mushrooms')
#运行结果
Making a 16-inch pizza with the following toppings:
----pepperoni
----mushrooms
size: 16
toppings:
==== pepperoni
==== mushrooms

语法:import module_name as mn

 

导入模块中所有的函数

#pizza
from make_pizza import *
make_pizza1(16,'pepperoni','mushrooms')
make_pizza2(16,'pepperoni','mushrooms')
#运行结果
Making a 16-inch pizza with the following toppings:
----pepperoni
----mushrooms
size: 16
toppings:
==== pepperoni
==== mushrooms

*可以代表前面指定模块里的所有函数。

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

《Python编程从入门到实践》_第八章_函数的更多相关文章

  1. 《Python编程从入门到实践》第二章_变量和简单数据类型

    什么是变量呢? 举例: >>> message = "Hello,Python!" >>> print (message) Hello,Pyth ...

  2. 《Python编程从入门到实践》_第十章_文件和异常

    读取整个文件 文件pi_digits.txt #文件pi_digits.txt 3.1415926535 8979323846 2643383279 下面的程序打开并读取整个文件,再将其内容显示到屏幕 ...

  3. 《python编程从入门到实践》读书实践笔记(一)

    本文是<python编程从入门到实践>读书实践笔记1~10章的内容,主要包含安装.基础类型.函数.类.文件读写及异常的内容. 1 起步 1.1 搭建环境 1.1.1 Python 版本选择 ...

  4. Python编程从入门到实践笔记——异常和存储数据

    Python编程从入门到实践笔记——异常和存储数据 #coding=gbk #Python编程从入门到实践笔记——异常和存储数据 #10.3异常 #Python使用被称为异常的特殊对象来管理程序执行期 ...

  5. Python编程从入门到实践笔记——文件

    Python编程从入门到实践笔记——文件 #coding=gbk #Python编程从入门到实践笔记——文件 #10.1从文件中读取数据 #1.读取整个文件 file_name = 'pi_digit ...

  6. Python编程从入门到实践笔记——类

    Python编程从入门到实践笔记——类 #coding=gbk #Python编程从入门到实践笔记——类 #9.1创建和使用类 #1.创建Dog类 class Dog():#类名首字母大写 " ...

  7. Python编程从入门到实践笔记——函数

    Python编程从入门到实践笔记——函数 #coding=gbk #Python编程从入门到实践笔记——函数 #8.1定义函数 def 函数名(形参): # [缩进]注释+函数体 #1.向函数传递信息 ...

  8. Python编程从入门到实践笔记——用户输入和while循环

    Python编程从入门到实践笔记——用户输入和while循环 #coding=utf-8 #函数input()让程序暂停运行,等待用户输入一些文本.得到用户的输入以后将其存储在一个变量中,方便后续使用 ...

  9. Python编程从入门到实践笔记——字典

    Python编程从入门到实践笔记——字典 #coding=utf-8 #字典--放在{}中的键值对:跟json很像 #键和值之间用:分隔:键值对之间用,分隔 alien_0 = {'color':'g ...

  10. Python编程从入门到实践笔记——if语句

    Python编程从入门到实践笔记——if语句 #coding=utf-8 cars=['bwm','audi','toyota','subaru','maserati'] bicycles = [&q ...

随机推荐

  1. [译] 关于 SPA,你需要掌握的 4 层 (2)

    此文已由作者张威授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验. 视图层 现在我们有了一个可执行且不依赖于框架的应用程序,React 已经准备投入使用. 视图层由 presen ...

  2. session相关

    判断session是否已失效: HttpSession session=request.getSession(false); getSession(boolean)相比于getSession()更安全 ...

  3. OC 术语表

    术语表 本附录包含了很多会用到的非正式定义术语.有些术语与Obective-C语言有关,其他术语则有自己的语源,来自面向对象程序设计的规范.在后一种情况中,术语的含义只有明确应用于Obective-C ...

  4. 【ARC077F】SS kmp+打表找规律

    Description ​ 如果某个串可以由两个一样的串前后连接得到,我们就称之为"偶串".比如说"xyzxyz"和"aaaaaa"是偶串, ...

  5. iOS 开发之 GCD 基础

    header{font-size:1em;padding-top:1.5em;padding-bottom:1.5em} .markdown-body{overflow:hidden} .markdo ...

  6. js 删除removeChild与替换replaceChild

    <input type="button" value="删除" id="btn" /> <input type=" ...

  7. RNA-seq分析htseq-count的使用

    HTSeq作为一款可以处理高通量数据的python包,由Simon Anders, Paul Theodor Pyl, Wolfgang Huber等人携手推出HTSeq — A Python fra ...

  8. C++_新特性1-类型转换运算符

    C++的创始人认为C语言的类型转换运算符太过于松散.他采取了更加严格的限制允许的类型转换.并添加了4个类型转换运算符. 这部分特性比较高阶,我把它归于奇技淫巧的范畴.这里简单介绍一下,以后实际有用到再 ...

  9. LeetCode109. 有序链表转换二叉搜索树

    109. 有序链表转换二叉搜索树 问题描述 给定一个单链表,其中的元素按升序排序,将其转换为高度平衡的二叉搜索树. 本题中,一个高度平衡二叉树是指一个二叉树每个节点 的左右两个子树的高度差的绝对值不超 ...

  10. 获取HTML代码用 像阿里巴巴

         public string GetHtml(string url)         {               string html = String .Empty;          ...