1.1 python 函数

   1、函数作用

      定义: 函数是指将一组语句的集合通过一个名字(函数名)封装起来,要想执行这个函数,只需调用其函数名即可

       特性:

      1. 减少重复代码
      2. 使程序变的可扩展
      3. 使程序变得易维护

  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、嵌套函数

      定义:看上面的标题的意思是,函数还能套函数

  1. name = "Tom"
  2.  
  3. def change_name():
  4. name = "Tom2"
  5.  
  6. def change_name2():
  7. name = "Tom3"
  8. print("最先执行内层函数", name)
  9.  
  10. change_name2() # 调用内层函数
  11. print("然后执行外层函数", name)
  12.  
  13. change_name()
  14. print("最后执行全局,局部变量只在局部起作用", name)

嵌套函数

  4、递归

      1. 在函数内部,可以调用其他函数。如果一个函数在内部调用自身本身,这个函数就是递归函数。

      2. 递归特性:

          1. 必须有一个明确的结束条件

          2. 每次进入更深一层递归时,问题规模相比上次递归都应有所减少

          3. 递归效率不高,递归层次过多会导致栈溢出(在计算机中,函数调用是通过栈(stack)这种数据结构实现的,每当进入一个函数调用,

           栈就会加一层栈帧,每当函数返回,栈就会减一层栈帧。由于栈的大小不是无限的,所以,递归调用的次数过多,会导致栈溢出)

  1. def calc(n):
  2. print(n)
  3. if int(n / 2) == 0:
  4. return n
  5. return calc(int(n / 2))
  6. calc(10)
  7.  
  8. # 输出:
  9. #
  10. #
  11. #
  12. #

递归基本使用

  1. data = [1, 3, 6, 7, 9, 12, 14, 16, 17, 18, 20, 21, 22, 23, 30, 32, 33, 35]
  2.  
  3. def binary_search(dataset, find_num):
  4. print(dataset)
  5.  
  6. if len(dataset) > 1:
  7. mid = int(len(dataset) / 2)
  8. if dataset[mid] == find_num: # find it
  9. print("找到数字", dataset[mid])
  10. elif dataset[mid] > find_num: # 找的数在mid左面
  11. print("\033[31;1m找的数在mid[%s]左面\033[0m" % dataset[mid])
  12. return binary_search(dataset[0:mid], find_num)
  13. else: # 找的数在mid右面
  14. print("\033[32;1m找的数在mid[%s]右面\033[0m" % dataset[mid])
  15. return binary_search(dataset[mid + 1:], find_num)
  16. else:
  17. if dataset[0] == find_num: # find it
  18. print("找到数字啦", dataset[0])
  19. else:
  20. print("没的分了,要找的数字[%s]不在列表里" % find_num)
  21.  
  22. binary_search(data, 66)

递归函数实际应用案例,二分查找

  1. def get_dept_path(deptid, dept_path=[], deptname_list=[]):
  2. dept_obj = Department.objects.get(id=deptid)
  3. if not dept_path:
  4. dept_path.append(deptid)
  5. try:
  6. dept_path.append(dept_obj.fid_id)
  7. get_dept_path(dept_obj.fid_id, dept_path)
  8. except Exception as e:
  9. pass
  10. deptname_list.append(dept_obj.name)
  11. return deptname_list
  12. print get_dept_path(385) # [u '医渡云', u '医药事业部', u 'Rwe部']

查找部门绝对路径

  5、匿名函数  

      定义: 匿名函数就是不需要显式的指定函数 

  1. res = map(lambda x:x**2,[1,5,7,4,8])
  2. for i in res:
  3. print(i)
  4. #执行结果:
  5. #
  6. #
  7. #
  8. #
  9. #

map与lambda结合

05: python中的函数的更多相关文章

  1. Python中split()函数的用法及实际使用示例

    Python中split()函数,通常用于将字符串切片并转换为列表. 一.函数说明: split():语法:str.split(str="",num=string.count(st ...

  2. Python中利用函数装饰器实现备忘功能

    Python中利用函数装饰器实现备忘功能 这篇文章主要介绍了Python中利用函数装饰器实现备忘功能,同时还降到了利用装饰器来检查函数的递归.确保参数传递的正确,需要的朋友可以参考下   " ...

  3. python中range()函数的用法

    python中range()函数可创建一个整数列表,一般用在for循环中. range()函数语法: range(start,stop[,step]) 参数说明: star: 计数从star开始.默认 ...

  4. Python 中的函数

    学了 Python 中的数据类型,语句,接下来就来说一下 Python 中的函数,函数是结构化编程的核心.我们使用函数可以增加程序的可读性.自定义函数时使用关键字def 函数由多条语句组成.在定义函数 ...

  5. python中format函数

    python中format函数用于字符串的格式化 通过关键字 1 print('{名字}今天{动作}'.format(名字='陈某某',动作='拍视频'))#通过关键字 2 grade = {'nam ...

  6. Python中readline()函数 去除换行符

    从Python中readline()函数读取的一行内容中含有换行符\n,很多时候我们需要处理不含有换行符的字符串,此时就要去掉换行符\n. 方法是使用strip()函数. 例子如下: f = open ...

  7. Python中int()函数的用法浅析

      int()是Python的一个内部函数 Python系统帮助里面是这么说的 >>> help(int)  Help on class int in module __builti ...

  8. 【313】python 中 print 函数用法总结

    参考:python 中 print 函数用法总结 参考:Python print() 函数(菜鸟教程) 参考:Python 3 print 函数用法总结 目录: 字符串和数值类型 变量 格式化输出 p ...

  9. python中filter函数

    python中filter()函数   filter()函数是 Python 内置的另一个有用的高阶函数,filter()函数接收一个函数 f 和一个list,这个函数 f 的作用是对每个元素进行判断 ...

随机推荐

  1. R数据可视化手册学习简单的绘制常见的图形

    1.绘制散点图 # 使用ggplot2 library(ggplot2) ggplot(data = mtcars, aes(x = wt, y = mpg)) + geom_point() 2.绘制 ...

  2. Codeforces 349C - Mafia

    time limit per test 2 seconds memory limit per test 256 megabytes input standard input output standa ...

  3. hdfs启用垃圾站功能

    在core-site.xml文件中添加如下内容: ##开启回收站功能,设置保存7天删除数据信息        <property>                <name>f ...

  4. centos 7 yum configuration; yum localinstall

    Linux下对于软件包的管理使用rpm管理方式.直接使用rpm包管理工具来进行rpm包的安装,升级,卸载时,对于最让人头疼的莫过与包之间的依赖关系.yum作为一个rpm包前端管理工具,可以自动处理依赖 ...

  5. LoadRunner-参数化(连接数据库)

    多用户并发测试,用户信息来自数据库,对脚本中accounts值替换为参数后,打开参数列表. 1.点击 Data Wizard...:选择Specify SQL statement manu: 2.点击 ...

  6. Balanced Lineup---poj3264线段树基础

    题目链接 求对应区间最大值与最小值的差: #include<stdio.h> #include<string.h> #include<algorithm> #inc ...

  7. cookie的封装写法

    设置cookie 三个参数分别代表:键,值,过期时间,这个封装方法可以完成cookie的储存   以及cookie的删除(过期时间设为赋值) function setCookie(cname,cval ...

  8. Linux和Windows下查看环境变量方法(转)

    add by zhj: 本文中的Linux是指Ubuntu14.04 以前我对环境变量有误解,以为环境变量就是PATH这个变量.其实环境变量其实有很多,PATH仅仅是其中一个而已,比如在Windows ...

  9. springboot中的日志配置

    日志方式:每天日志存放在一个文件中,info和warn日志存放一个文件,error存放一个文件 创建文件 logback-spring.xml <?xml version="1.0&q ...

  10. Saving Princess claire_(hdu 4308 bfs模板题)

    http://acm.hdu.edu.cn/showproblem.php?pid=4308 Saving Princess claire_ Time Limit: 2000/1000 MS (Jav ...