05: python中的函数
1.1 python 函数
1、函数作用
定义: 函数是指将一组语句的集合通过一个名字(函数名)封装起来,要想执行这个函数,只需调用其函数名即可
特性:
- 减少重复代码
- 使程序变的可扩展
- 使程序变得易维护
2、函数参数与局部变量
1. 函数中的形参与实参
1)形参变量只有在被调用时才分配内存单元,在调用结束时,即刻释放所分配的内存单元。因此,形参只在函数内部有效。
函数调用结束返回主调用函数后则不能再使用该形参变量
2)实参可以是常量、变量、表达式、函数等,无论实参是何种类型的量,在进行函数调用时,它们都必须有确定的值,
以便把这些值传送给形参。因此应预先用赋值,输入等办法使参数获得确定值
2. python函数三种参数
1)位置参数
def
stu_register(name,age,course
):
2)关键参数
正常情况下,给函数传参数要按顺序,不想按顺序就可以用关键参数,只需指定参数名即可,但记住一个要求就是,关键参数必须放在位置参数之后。
stu_register(age
=
22
,name
=
'alex'
,course
=
"python"
,)
3)非固定参数
若你的函数在定义时不确定用户想传入多少个参数,就可以使用非固定参数
def
stu_register(name,age,
*
args,
*
*
kwargs):
# *kwargs 会把多传入的参数变成一个dict形式
3. 全局与局部变量
4. 返回值
要想获取函数的执行结果,就可以用return语句把结果返回
函数在执行过程中只要遇到return语句,就会停止执行并返回结果,so 也可以理解为 return 语句代表着函数的结束
如果未在函数中指定return,那这个函数的返回值为None
3、嵌套函数
定义:看上面的标题的意思是,函数还能套函数
- name = "Tom"
- def change_name():
- name = "Tom2"
- def change_name2():
- name = "Tom3"
- print("最先执行内层函数", name)
- change_name2() # 调用内层函数
- print("然后执行外层函数", name)
- change_name()
- print("最后执行全局,局部变量只在局部起作用", name)
嵌套函数
4、递归
1. 在函数内部,可以调用其他函数。如果一个函数在内部调用自身本身,这个函数就是递归函数。
2. 递归特性:
1. 必须有一个明确的结束条件
2. 每次进入更深一层递归时,问题规模相比上次递归都应有所减少
3. 递归效率不高,递归层次过多会导致栈溢出(在计算机中,函数调用是通过栈(stack)这种数据结构实现的,每当进入一个函数调用,
栈就会加一层栈帧,每当函数返回,栈就会减一层栈帧。由于栈的大小不是无限的,所以,递归调用的次数过多,会导致栈溢出)
- def calc(n):
- print(n)
- if int(n / 2) == 0:
- return n
- return calc(int(n / 2))
- calc(10)
- # 输出:
- #
- #
- #
- #
递归基本使用
- data = [1, 3, 6, 7, 9, 12, 14, 16, 17, 18, 20, 21, 22, 23, 30, 32, 33, 35]
- def binary_search(dataset, find_num):
- print(dataset)
- if len(dataset) > 1:
- mid = int(len(dataset) / 2)
- if dataset[mid] == find_num: # find it
- print("找到数字", dataset[mid])
- elif dataset[mid] > find_num: # 找的数在mid左面
- print("\033[31;1m找的数在mid[%s]左面\033[0m" % dataset[mid])
- return binary_search(dataset[0:mid], find_num)
- else: # 找的数在mid右面
- print("\033[32;1m找的数在mid[%s]右面\033[0m" % dataset[mid])
- return binary_search(dataset[mid + 1:], find_num)
- else:
- if dataset[0] == find_num: # find it
- print("找到数字啦", dataset[0])
- else:
- print("没的分了,要找的数字[%s]不在列表里" % find_num)
- binary_search(data, 66)
递归函数实际应用案例,二分查找
- def get_dept_path(deptid, dept_path=[], deptname_list=[]):
- dept_obj = Department.objects.get(id=deptid)
- if not dept_path:
- dept_path.append(deptid)
- try:
- dept_path.append(dept_obj.fid_id)
- get_dept_path(dept_obj.fid_id, dept_path)
- except Exception as e:
- pass
- deptname_list.append(dept_obj.name)
- return deptname_list
- print get_dept_path(385) # [u '医渡云', u '医药事业部', u 'Rwe部']
查找部门绝对路径
5、匿名函数
定义: 匿名函数就是不需要显式的指定函数
- res = map(lambda x:x**2,[1,5,7,4,8])
- for i in res:
- print(i)
- #执行结果:
- #
- #
- #
- #
- #
map与lambda结合
05: python中的函数的更多相关文章
- Python中split()函数的用法及实际使用示例
Python中split()函数,通常用于将字符串切片并转换为列表. 一.函数说明: split():语法:str.split(str="",num=string.count(st ...
- Python中利用函数装饰器实现备忘功能
Python中利用函数装饰器实现备忘功能 这篇文章主要介绍了Python中利用函数装饰器实现备忘功能,同时还降到了利用装饰器来检查函数的递归.确保参数传递的正确,需要的朋友可以参考下 " ...
- python中range()函数的用法
python中range()函数可创建一个整数列表,一般用在for循环中. range()函数语法: range(start,stop[,step]) 参数说明: star: 计数从star开始.默认 ...
- Python 中的函数
学了 Python 中的数据类型,语句,接下来就来说一下 Python 中的函数,函数是结构化编程的核心.我们使用函数可以增加程序的可读性.自定义函数时使用关键字def 函数由多条语句组成.在定义函数 ...
- python中format函数
python中format函数用于字符串的格式化 通过关键字 1 print('{名字}今天{动作}'.format(名字='陈某某',动作='拍视频'))#通过关键字 2 grade = {'nam ...
- Python中readline()函数 去除换行符
从Python中readline()函数读取的一行内容中含有换行符\n,很多时候我们需要处理不含有换行符的字符串,此时就要去掉换行符\n. 方法是使用strip()函数. 例子如下: f = open ...
- Python中int()函数的用法浅析
int()是Python的一个内部函数 Python系统帮助里面是这么说的 >>> help(int) Help on class int in module __builti ...
- 【313】python 中 print 函数用法总结
参考:python 中 print 函数用法总结 参考:Python print() 函数(菜鸟教程) 参考:Python 3 print 函数用法总结 目录: 字符串和数值类型 变量 格式化输出 p ...
- python中filter函数
python中filter()函数 filter()函数是 Python 内置的另一个有用的高阶函数,filter()函数接收一个函数 f 和一个list,这个函数 f 的作用是对每个元素进行判断 ...
随机推荐
- R数据可视化手册学习简单的绘制常见的图形
1.绘制散点图 # 使用ggplot2 library(ggplot2) ggplot(data = mtcars, aes(x = wt, y = mpg)) + geom_point() 2.绘制 ...
- Codeforces 349C - Mafia
time limit per test 2 seconds memory limit per test 256 megabytes input standard input output standa ...
- hdfs启用垃圾站功能
在core-site.xml文件中添加如下内容: ##开启回收站功能,设置保存7天删除数据信息 <property> <name>f ...
- centos 7 yum configuration; yum localinstall
Linux下对于软件包的管理使用rpm管理方式.直接使用rpm包管理工具来进行rpm包的安装,升级,卸载时,对于最让人头疼的莫过与包之间的依赖关系.yum作为一个rpm包前端管理工具,可以自动处理依赖 ...
- LoadRunner-参数化(连接数据库)
多用户并发测试,用户信息来自数据库,对脚本中accounts值替换为参数后,打开参数列表. 1.点击 Data Wizard...:选择Specify SQL statement manu: 2.点击 ...
- Balanced Lineup---poj3264线段树基础
题目链接 求对应区间最大值与最小值的差: #include<stdio.h> #include<string.h> #include<algorithm> #inc ...
- cookie的封装写法
设置cookie 三个参数分别代表:键,值,过期时间,这个封装方法可以完成cookie的储存 以及cookie的删除(过期时间设为赋值) function setCookie(cname,cval ...
- Linux和Windows下查看环境变量方法(转)
add by zhj: 本文中的Linux是指Ubuntu14.04 以前我对环境变量有误解,以为环境变量就是PATH这个变量.其实环境变量其实有很多,PATH仅仅是其中一个而已,比如在Windows ...
- springboot中的日志配置
日志方式:每天日志存放在一个文件中,info和warn日志存放一个文件,error存放一个文件 创建文件 logback-spring.xml <?xml version="1.0&q ...
- Saving Princess claire_(hdu 4308 bfs模板题)
http://acm.hdu.edu.cn/showproblem.php?pid=4308 Saving Princess claire_ Time Limit: 2000/1000 MS (Jav ...