为什么要用函数

现在python届发生了一个大事件,len方法突然不能直接用了。。。

然后现在有一个需求,让你计算'hello world'的长度,你怎么计算?

这个需求对于现在的你其实不难,我们一起来写一下。

  1. s1 = "hello world"
  2. length = 0
  3. for i in s1:
  4. length = length+1
  5.  
  6. print(length)

for循环实现len功能1

好了,功能实现了,非常完美。然后现在又有了一个需求,要计算另外一个字符串的长度,"hello eva".

于是,这个时候你的代码就变成了这样:

  1. s1 = "hello world"
  2. length = 0
  3. for i in s1:
  4. length = length+1
  5.  
  6. print(length)
  7.  
  8. s2 = "hello eva"
  9. length = 0
  10. for i in s2:
  11. length = length+1
  12.  
  13. print(length)

for循环实现len功能2

这样确实可以实现len方法的效果,但是总感觉不是那么完美?为什么呢?

首先,之前只要我们执行len方法就可以直接拿到一个字符串的长度了,现在为了实现相同的功能我们把相同的代码写了好多遍 —— 代码冗余

其次,之前我们只写两句话读起来也很简单,一看就知道这两句代码是在计算长度,但是刚刚的代码却不那么容易读懂 —— 可读性差

  1. print(len(s1))
  2. print(len(s2))

我们就想啊,要是我们能像使用len一样使用我们这一大段“计算长度”的代码就好了。这种感觉有点像给这段代码起了一个名字,等我们用到的时候直接喊名字就能执行这段代码似的。要是能这样,是不是很完美啊?

初识函数定义与调用

现在就教大家一个既能,让你们把代码装起来。

  1. def mylen():
  2. s1 = "hello world"
  3. length = 0
  4. for i in s1:
  5. length = length+1
  6. print(length)

定义函数

我们一起来分析一下这段代码做了什么。

其实除了def这一行和后面的缩进,其他的好像就是正常的执行代码。我们来执行一下,哦,好像啥也没发生。

刚刚我们已经说过,这是把代码装起来的过程。你现在只会往里装,还不会往出拿。那么应该怎么往出拿呢?我来告诉大家:

mylen()

是不是很简单?是不是似曾相识?这就是代码取出来的过程。刚刚我们就写了一个函数,并且成功调用了它。

  1. #函数定义
  2. def mylen():
  3. """计算s1的长度"""
  4. s1 = "hello world"
  5. length = 0
  6. for i in s1:
  7. length = length+1
  8. print(length)
  9.  
  10. #函数调用
  11. mylen()

函数的定义和调用

总结一:

定义:def 关键词开头,空格之后接函数名称和圆括号(),最后还有一个":"。

   def 是固定的,不能变,必须是连续的def三个字母,不能分开。。。它们要相亲相爱的在一起。

   空格 为了将def关键字和函数名分开,必须空(四声),当然你可以空2格、3格或者你想空多少都行,但正常人还是空1格。

   函数名:函数名只能包含字符串、下划线和数字且不能以数字开头。虽然函数名可以随便起,但我们给函数起名字还是要尽量简短,并能表达函数功能

   括号:是必须加的,先别问为啥要有括号,总之加上括号就对了!

注释:每一个函数都应该对功能和参数进行相应的说明,应该写在函数下面第一行。以增强代码的可读性。

调用:就是 函数名() 要记得加上括号,好么好么好么。

函数的返回值

刚刚我们就写了一个函数,这个函数可以帮助我们计算字符串的长度,并且把结果打印出来。但是,这和我们的len方法还不是太一样。哪里不一样呢?以前我们调用len方法会得到一个值,我们必须用一个变量来接收这个值。

  1. str_len = len('hello,world')

这个str_len就是‘hello,world’的长度。那我们自己写的函数能做到这一点么?我们也来试一下。

  1. #函数定义
  2. def mylen():
  3. """计算s1的长度"""
  4. s1 = "hello world"
  5. length = 0
  6. for i in s1:
  7. length = length+1
  8. print(length)
  9.  
  10. #函数调用
  11. str_len = mylen()
  12. print('str_len : %s'%str_len)

函数调用的结果

很遗憾,如果你执行这段代码,得到的str_len 值为None,这说明我们这段代码什么也没有给你返回。

那如何让它也像len函数一样返回值呢?

  1. #函数定义
  2. def mylen():
  3. """计算s1的长度"""
  4. s1 = "hello world"
  5. length = 0
  6. for i in s1:
  7. length = length+1
  8. return length
  9.  
  10. #函数调用
  11. str_len = mylen()
  12. print('str_len : %s'%str_len)

我们只需要在函数的最后加上一个return,return后面写上你要返回的值就可以了。

接下来,我们就来研究一下这个return的用法。

return关键字的作用

  return 是一个关键字,在pycharm里,你会看到它变成蓝色了。你必须一字不差的把这个单词给背下来。

  这个词翻译过来就是“返回”,所以我们管写在return后面的值叫“返回值”

要研究返回值,我们还要知道返回值有几种情况:分别是没有返回值、返回一个值、返回多个值

没有返回值

  不写return的情况下,会默认返回一个None:我们写的第一个函数,就没有写return,这就是没有返回值的一种情况。 

  1. #函数定义
  2. def mylen():
  3. """计算s1的长度"""
  4. s1 = "hello world"
  5. length = 0
  6. for i in s1:
  7. length = length+1
  8. print(length)
  9.  
  10. #函数调用
  11. str_len = mylen()
  12. #因为没有返回值,此时的str_len为None
  13. print('str_len : %s'%str_len)

不写return

  只写return,后面不写其他内容,也会返回None,有的同学会奇怪,既然没有要返回的值,完全可以不写return,为什么还要写个return呢?这里我们要说一下return的其他用法,就是一旦遇到return,结束整个函数。  

  1. def ret_demo():
  2. print(111)
  3. return
  4. print(222)
  5.  
  6. ret = ret_demo()
  7. print(ret)

只写return

return None:和上面的两种情况一样,我们一般不这样写。

  1. def ret_demo():
  2. print(111)
  3. return None
  4. print(222)
  5.  
  6. ret = ret_demo()
  7. print(ret)

retutn None

返回一个值

刚刚我们已经写过一个返回一个值的情况,只需在return后面写上要返回的内容即可。  

  1. #函数定义
  2. def mylen():
  3. """计算s1的长度"""
  4. s1 = "hello world"
  5. length = 0
  6. for i in s1:
  7. length = length+1
  8. return length
  9.  
  10. #函数调用
  11. str_len = mylen()
  12. print('str_len : %s'%str_len)

返回一个值

  注意:return和返回值之间要有空格,可以返回任意数据类型的值

返回多个值

  可以返回任意多个、任意数据类型的值

  1. def ret_demo1():
  2. '''返回多个值'''
  3. return 1,2,3,4
  4.  
  5. def ret_demo2():
  6. '''返回多个任意类型的值'''
  7. return 1,['a','b'],3,4
  8.  
  9. ret1 = ret_demo1()
  10. print(ret1)
  11. ret2 = ret_demo2()
  12. print(ret2)

返回多个值

  返回的多个值会被组织成元组被返回,也可以用多个值来接收

  1. def ret_demo2():
  2. return 1,['a','b'],3,4
  3.  
  4. #返回多个值,用一个变量接收
  5. ret2 = ret_demo2()
  6. print(ret2)
  7.  
  8. #返回多个值,用多个变量接收
  9. a,b,c,d = ret_demo2()
  10. print(a,b,c,d)
  11.  
  12. #用多个值接收返回值:返回几个值,就用几个变量接收
  13. a,b,c,d = ret_demo2()
  14. print(a,b,c,d)

返回多个值的接收

  原因:  

  1. >>> 1,2 #python中把用逗号分割的多个值就认为是一个元组。
  2. (1, 2)
  3. >>> 1,2,3,4
  4. (1, 2, 3, 4)
  5. >>> (1,2,3,4)
  6. (1, 2, 3, 4)
  1. #序列解压一
  2. >>> a,b,c,d = (1,2,3,4)
  3. >>> a
  4. 1
  5. >>> b
  6. 2
  7. >>> c
  8. 3
  9. >>> d
  10. 4
  11. #序列解压二
  12. >>> a,_,_,d=(1,2,3,4)
  13. >>> a
  14. 1
  15. >>> d
  16. 4
  17. >>> a,*_=(1,2,3,4)
  18. >>> *_,d=(1,2,3,4)
  19. >>> a
  20. 1
  21. >>> d
  22. 4
  23. #也适用于字符串、列表、字典、集合
  24. >>> a,b = {'name':'eva','age':18}
  25. >>> a
  26. 'name'
  27. >>> b
  28. 'age'

函数的参数

现在,我们已经把函数返回值相关的事情研究清楚了,我们自己已经完成了一个可以返回字符串长度的函数。但是现在这个函数还是不完美,之前我们使用len函数的时候得是length = len("hello world"),这样我可以想计算谁就计算谁的长度。但是现在我们写的这个函数,只能计算一个“hello world”的长度,换一个字符串好像就是不行了。这可怎么办?

带参数的函数:

  1. #函数定义
  2. def mylen(s1):
  3. """计算s1的长度"""
  4. length = 0
  5. for i in s1:
  6. length = length+1
  7. return length
  8.  
  9. #函数调用
  10. str_len = mylen("hello world")
  11. print('str_len : %s'%str_len)

我们告诉mylen函数要计算的字符串是谁,这个过程就叫做 传递参数,简称传参,我们调用函数时传递的这个“hello world”和定义函数时的s1就是参数

实参与形参

参数还有分别:

我们调用函数时传递的这个“hello world”被称为实际参数,因为这个是实际的要交给函数的内容,简称实参。

定义函数时的s1,只是一个变量的名字,被称为形式参数,因为在定义函数的时候它只是一个形式,表示这里有一个参数,简称形参。  

传递多个参数

参数可以传递多个,多个参数之间用逗号分割。

  1. def mymax(x,y):
  2. the_max = x if x > y else y
  3. return the_max
  4.  
  5. ma = mymax(10,20)
  6. print(ma)

也正是因为需要传递多个参数、可以传递多个参数,才会有了后面这一系列参数相关的故事。。。

位置参数

 站在实参角度

  1.按照位置传值

  1. def mymax(x,y):
  2. #此时x=10,y=20
  3. the_max = x if x > y else y
  4. return the_max
  5.  
  6. ma = mymax(10,20)
  7. print(ma)

  2.按照关键字传值

  1. def mymax(x,y):
  2. #此时x = 20,y = 10
  3. print(x,y)
  4. the_max = x if x > y else y
  5. return the_max
  6.  
  7. ma = mymax(y = 10,x = 20)
  8. print(ma)

  3.位置、关键字形式混着用

  1. def mymax(x,y):
  2. #此时x = 10,y = 20
  3. print(x,y)
  4. the_max = x if x > y else y
  5. return the_max
  6.  
  7. ma = mymax(10,y = 20)
  8. print(ma)

正确用法

   问题一:位置参数必须在关键字参数的前面

   问题二:对于一个形参只能赋值一次      

站在形参角度

   位置参数必须传值

  1. def mymax(x,y):
  2. #此时x = 10,y = 20
  3. print(x,y)
  4. the_max = x if x > y else y
  5. return the_max
  6.  
  7. #调用mymax不传递参数
  8. ma = mymax()
  9. print(ma)
  10.  
  11. #结果
  12. TypeError: mymax() missing 2 required positional arguments: 'x' and 'y'

默认参数

1.正常使用

  使用方法

  为什么要有默认参数:将变化比较小的值设置成默认参数

2.默认参数的定义

  默认参数

  1. def stu_info(name,sex = "male"):
  2. """打印学生信息函数,由于班中大部分学生都是男生,
  3. 所以设置默认参数sex的默认值为'male'
  4. """
  5. print(name,sex)
  6.  
  7. stu_info('alex')
  8. stu_info('eva','female')

3.参数陷阱:默认参数是一个可变数据类型

  参数陷阱

  1. def defult_param(a,l = []):
  2. l.append(a)
  3. print(l)
  4.  
  5. defult_param('alex')
  6. defult_param('egon')

动态参数

按位置传值多余的参数都由args统一接收,保存成一个元组的形式

  *args和**kwargs函数应用

  1. def mysum(*args):
  2. the_sum = 0
  3. for i in args:
  4. the_sum+=i
  5. return the_sum
  6.  
  7. the_sum = mysum(1,2,3,4)
  8. print(the_sum)
  9.  
  10. def stu_info(**kwargs):
  11. print(kwargs)
  12. print(kwargs['name'],kwargs['sex'])
  13.  
  14. stu_info(name = 'alex',sex = 'male')

  实际开发中:

  未来还会用到的场景。。。

  问题:

    位置参数、默认参数、动态参数定义的顺序以及接收的结果?

本章小结

面向过程编程的问题:代码冗余、可读性差、可扩展性差(不易修改)

定义函数的规则:

  1. 1.定义:def 关键词开头,空格之后接函数名称和圆括号()。
  2. 2.参数:圆括号用来接收参数。若传入多个参数,参数之间用逗号分割。
        参数可以定义多个,也可以不定义。
        参数有很多种,如果涉及到多种参数的定义,应始终遵循位置参数、*args、默认参数、**kwargs顺序定义。
        如上述定义过程中某参数类型缺省,其他参数依旧遵循上述排序
  3. 3.注释:函数的第一行语句应该添加注释。
  4. 4.函数体:函数内容以冒号起始,并且缩进。
  5. 5.返回值:return [表达式] 结束函数。不带表达式的return相当于返回 None
  6.  
  7. def 函数名(参数1,参数2,*args,默认参数,**kwargs):
  8. """注释:函数功能和参数说明"""
  9. 函数体
  10. ……
  11. return 返回值

调用函数的规则:

  1. 1.函数名()
  2. 函数名后面+圆括号就是函数的调用。
  3. 2.参数:
  4. 圆括号用来接收参数。
  5. 若传入多个参数:
  6. 应按先位置传值,再按关键字传值
  7. 具体的传入顺序应按照函数定义的参数情况而定
  8. 3.返回值
  9. 如果函数有返回值,还应该定义“变量”接收返回值
  10. 如果返回值有多个,也可以用多个变量来接收,变量数应和返回值数目一致
  11.  
  12. 无返回值的情况:
  13. 函数名()
  14.  
  15. 有返回值的情况:
  16. 变量 = 函数名()
  17.  
  18. 多个变量接收多返回值:
  19. 变量1,变量2,... = 函数名()

参数总结:

Python_初识函数的更多相关文章

  1. Python_初识函数和返回值_22

    #len s = '金老板小护士' len(s) def my_len(): #自定义函数 i = 0 for k in s: i += 1 print(i) length = my_len() pr ...

  2. python之路——初识函数

    阅读目录 为什么要用函数 函数的定义与调用 函数的返回值 函数的参数 本章小结 返回顶部 为什么要用函数 现在python届发生了一个大事件,len方法突然不能直接用了... 然后现在有一个需求,让你 ...

  3. python基础 (初识函数&函数进阶)

    函数基础部分 .什么是函数? 函数是组织好的,可重复使用的,用来实现单一,或相关联功能的代码段. 函数能提高应用的模块性,和代码的重复利用率. 2.定义函数 定义:def 关键词开头,空格之后接函数名 ...

  4. Day06 (黑客成长日记) 初识函数和返回值的作用

    定义函数: 1.初识函数: 我们在学习字符串时,有这样的操作: li = 'tsy be ba bvake ' print(len(li)) 这样可以打印出li的长度,我们利用了python中的len ...

  5. python基础之 初识函数&函数进阶

    函数基础部分 1.什么是函数? 函数是组织好的,可重复使用的,用来实现单一,或相关联功能的代码段.函数能提高应用的模块性,和代码的重复利用率. 2.定义函数 定义:def 关键词开头,空格之后接函数名 ...

  6. Python基础之文件的初识函数

    初识函数函数定义:定义一个事情或者功能. 等到需要的时候直接去用就好了了. 那么这里定义的东西就是一个函数即函数: 对代码块和功能的封装和定义1.1常用形式: def 函数名(): 函数体1.2 函数 ...

  7. 08-Python之路---初识函数

    Python之路---初识函数️ 程序员三大美德: 懒惰 因为一直致力于减少工作的总工作量. 缺乏耐性 因为一旦让你去做本该计算机完成的事,你将会怒不可遏. 傲慢 因为被荣誉感冲晕头的你会把程序写得让 ...

  8. Python初识函数

    Python初识函数 函数理论篇 什么是函数 在编程语言中的函数不同于数学中的函数.不管是数学上的函数还是编程语言中的函数都是为了完成特定的某一功能而诞生的,他们的区别在于: 1.数学中的函数当输入的 ...

  9. Python函数01/函数的初识/函数的定义/函数调用/函数的返回值/函数的参数

    Python函数01/函数的初识/函数的定义/函数调用/函数的返回值/函数的参数 内容大纲 1.函数的初识 2.函数的定义 3.函数的调用 4.函数的返回值 5.函数的参数 1.函数初识 # def ...

随机推荐

  1. 框架里增加.env文件的作用

    在实际开发中我们常常遇到这样的问题,就是开发地点不固定,这就造成了我们需要频繁的更改数据库配置,给开发工作造成了麻烦,.env环境文件的出现解决了这个麻烦,我们只需要在不同的工作地点配置好.env文件 ...

  2. UniGUI之UniLabel(31)

    1]改变文本Caption 2]改变颜色字体Font 3]点击访问网址,OnClick事件 1]改变文本Caption unilabel1.Caption:='unilabel1文本'; 2]改变颜色 ...

  3. Spark学习之路 (二十三)SparkStreaming的官方文档[转]

    SparkCore.SparkSQL和SparkStreaming的类似之处 SparkStreaming的运行流程 1.我们在集群中的其中一台机器上提交我们的Application Jar,然后就会 ...

  4. 剑指offer-面试题8-二叉树的下一个节点-二叉树

    /* 题目: 给定一棵二叉树和其中一个节点,找出中序遍历的下一个节点. */ /* 思路: 两种情况: 节点存在右子树:节点右子树的最左节点: 节点不存在右子树,节点向上一直找父节点或祖父节点,直到其 ...

  5. python ide 使用

    pycharm jupyter 官方文档 使用 部署到服务器 参考 配置域名(反向代理) *.conf文件 server { listen ; server_name ju.iii.top; inde ...

  6. 【32】Padding(填充)原理讲解

    Padding 为了构建深度神经网络,你需要学会使用的一个基本的卷积操作就是padding,让我们来看看它是如何工作的.   我们在之前笔记中看到,如果你用一个3×3的过滤器卷积一个6×6的图像,你最 ...

  7. Java集合之Collections 剖析

    Collections工具类位于 java.util 包下,是一个比较常用的工具类,关于这个工具类,主要介绍其在使用过程中遇到的大坑!!! [事故现场] 在实际项目开发过程中,在前人代码的基础上,对于 ...

  8. Java锁机制深入理解

    Java锁机制 背景知识 指令流水线 ​ CPU的基本工作是执行存储的指令序列,即程序.程序的执行过程实际上是不断地取出指令.分析指令.执行指令的过程. ​ 几乎所有的冯•诺伊曼型计算机的CPU,其工 ...

  9. mysql 数据库优化的几种方法

    1.选取最适用的字段属性 MySQL可以很好的支持大数据量的存取,但是一般说来,数据库中的表越小,在它上面执行的查询也就会越快.因此,在创建表的时候,为了获得更好的性能,我们可以将表中字段的宽度设得尽 ...

  10. unity ui中使用onmouseover

    unity ui中鼠标移进或者移出的触发方式与2d.3d的不同,2d.3d物体使用的是onmouseover,ui使用的是OnPointerEnter.需要实现以下两个接口. public class ...