函数 

  函数是组织好的,可重复使用的,用来实现单一,或相关联功能的代码段。

  函数能提高应用的模块性,和代码的重复利用率。你已经知道Python提供了许多内建函数,比如print()。但你也可以自己创建函数,这被叫做用户自定义函数。

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

  特性:

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

定义一个函数

  语法定义:

1 def sayhi():#函数名
2 print("Hello, I'm nobody!")
3
4 sayhi() #调用函数

  实例:

>>> def hello() :
print("Hello World!") >>> hello()
Hello World!
>>>

  带参数:

#下面这段代码
a,b = 5,8
c = a**b
print(c) #改成用函数写
def calc(x,y):
res = x**y
return res #返回函数执行结果 c = calc(a,b) #结果赋值给c变量
print(c)

函数参数和环境变量

参数

  默认参数:

  位置参数:

  形参:变量只有在被调用时才分配内存单元,在调用结束时,即刻释放所分配的内存单元。因此,形参只在函数内部有效。函数调用结束返回主调用函数后则不能再使用该形参变量

  实参:可以是常量、变量、表达式、函数等,无论实参是何种类型的量,在进行函数调用时,它们都必须有确定的值,以便把这些值传送给形参。因此应预先用赋值,输入等办法使参数获得确定值

  实例图:

  

默认参数

  定义:调用函数时,如果没有传递参数,则会使用默认参数。

  默认参数必须放到非默认参数(位置参数)的右面;

 1 def sayHi(name,age,nationality='CN'):
2 print("Hello,I'm %s !"%name,age,nationality)
3
4 sayHi('lain','24') #默认显示国籍为'CN'
5 sayHi('liha','22','USA') #修改默认国籍为'USA'
6
7
8 结果:
9 Hello,I'm lain ! 24 CN
10 Hello,I'm liha ! 22 USA

指定参数

  指定参数必须放在位置参数的右面;

1 def sayHi(name,age,nationality='CN'):
2 print("Hello,I'm %s !"%name,age,nationality)
3
4 sayHi('lain',nationality='JP',age=24)
5 sayHi('liha',age=22,nationality='USA')
6
7 运行结果:
8 Hello,I'm lain ! 24 JP
9 Hello,I'm liha ! 22 USA

非固定参数(不定长参数)

  一个函数能处理比当初声明时更多的参数。这些参数叫做不定长参数,和上述2种参数不同,声明时不会命名;

  命名规范*args,**kwargs

  元组形式:加一个星号(*)的变量名会存放所有未命名的变量参数。如果在函数调用时没有指定参数,它就是一个空元组

 1 def stu_register(name, age, country, course,*heh):
2 print("----注册学生信息------")
3 print("姓名:", name)
4 print("age:", age)
5 print("国籍:", country)
6 print("课程:", course)
7 print("爱好:",*heh)
8
9
10 stu_register("张三", 22, "CN", "Python_devops",'妹纸','聊天')
11 stu_register("李四", 24, "CN", "Linux","玩蛋")
12 stu_register("王三炮", 25, "CN", "Oracle",'LOL')
13
14 执行结果:
15 ----注册学生信息------
16 姓名: 张三
17 age: 22
18 国籍: CN
19 课程: Python_devops
20 爱好: 妹纸 聊天
21 ----注册学生信息------
22 姓名: 李四
23 age: 24
24 国籍: CN
25 课程: Linux
26 爱好: 玩蛋
27 ----注册学生信息------
28 姓名: 王三炮
29 age: 25
30 国籍: CN
31 课程: Oracle
32 爱好: LOL

  字典形式:加两个星号(**)的变量名会存放所有未命名的变量参数。如果在函数调用时没有指定参数,它就是一个空字典

 1 def stu_register(name, age, country, course,*heh,**hah):
2 print("----注册学生信息------")
3 print("姓名:", name)
4 print("age:", age)
5 print("国籍:", country)
6 print("课程:", course)
7 print("爱好:",heh,hah)
8
9
10 stu_register("张三", 22, "CN", "Python_devops",'妹纸','聊天',stuid='134123',fee=4000)
11 stu_register("李四", 24, "CN", "Linux","玩蛋")
12 stu_register("王三炮", 25, "CN", "Oracle",'LOL')
13
14 执行结果:
15 ----注册学生信息------
16 姓名: 张三
17 age: 22
18 国籍: CN
19 课程: Python_devops
20 爱好: ('妹纸', '聊天') {'stuid': '134123', 'fee': 4000}
21 ----注册学生信息------
22 姓名: 李四
23 age: 24
24 国籍: CN
25 课程: Linux
26 爱好: ('玩蛋',) {}
27 ----注册学生信息------
28 姓名: 王三炮
29 age: 25
30 国籍: CN
31 课程: Oracle
32 爱好: ('LOL',) {}

递归函数

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

  递归特性:

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

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

  3. 递归效率不高,递归层次过多会导致栈溢出(在计算机中,函数调用是通过栈(stack)这种数据结构实现的,每当进入一个函数调用,栈就会加一层栈帧,每当函数返回,栈就会减一层栈帧。由于栈的大小不是   无限的,所以,递归调用的次数过多,会导致栈溢出)

 1 data = range(0,1000000)
2
3 def digui(data,find):
4 if len(data) > 0:
5 middle_pos = int(len(data)/2)
6 if data[middle_pos] == find:
7 print('find_name:',find)
8 elif data[middle_pos] < find:
9 print('\033[31;1m 右边的值:%s\033[0m',data[middle_pos+1:])
10 digui(data[middle_pos+1:],find)
11 else:
12 print('\033[32;1m 左边的值:%s\033[0m',data[0:middle_pos])
13 digui(data[0:middle_pos],find)
14 else:
15 print('没有找到!')
16
17 digui(data,451232)

环境变量

  1.函数外声明的是全局变量,函数内声明的是局部变量;

  2.全局变量作用域是整个程序,局部变量作用域是定义该变量的子程序;

  3.当全局变量与局部变量同名时:

    在定义局部变量的子程序内,局部变量起作用;在其它地方全局变量起作用。

  4.正常情况下,局部环境变量无法修改全局变量;可以使用global命令:

 1 login_status=True
2 def login():
3 #global login_status
4 login_status=False
5 if login_status==True:
6 print('login_status is True')
7 else:
8 print('login_status is False')
9
10 login()
11 print(login_status)
12
13 运行结果:
14 #注释global
15 login_status is False
16 True
17 #使用global
18 login_status is False
19 False

函数返回值  

  要想获取函数的执行结果,就可以用return语句把结果返回

  注意:

  1. 一旦函数经过调用并开始执行,那函数外部的程序,就无法再控制函数的执行过程,只能等待函数执行结果;所以return语句代表着函数的结束

  2. 如果未在函数中指定return,那这个函数的返回值为None

匿名函数

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

1 #非匿名函数
2 def calc(x,y):
3 runturn x*y
4 print(calc(3,4))
5
6 #匿名函数
7 calc = lambda x,y:x*y
8 print(calc(3,4))

  匿名函数搭配map()方法使用

 1 def calc(n):
2 return n*n
3
4 data = map(calc,range(10))
5
6 for i in data:
7 print(i)
8
9 ======================
10 data = map(lambda n:n*n,range(10))
11 print(data)
12
13 data = map(lambda n:n*2,range(10))
14 print(data)
15
16 for i in data:
17 print(i)
18
19 =======================
20 data = map(lambda n:n*2 if n>5 else n,range(10))
21 print(data)
22
23 for i in data:
24 print(i)

高阶函数

  变量可以指向函数,函数的参数能接收变量,那么一个函数就可以接收另一个函数作为参数,这种函数就称之为高阶函数。

1 def add(x,y,f):
2 return f(x) + f(y)
3
4 res = add(3,-6,abs)
5 print(res)
6
7 #x,y表示形参
8 #f表示内置函数abs

Python运维开发之路《函数》的更多相关文章

  1. python运维开发之路第一天

    一.python安装及环境变量配置 1.windows7安装python 1)下载地址:https://www.python.org/downloads/windows/ 如下图: 注意:下载,用代理 ...

  2. Python运维开发基础09-函数基础【转】

    上节作业回顾 #!/usr/bin/env python3 # -*- coding:utf-8 -*- # author:Mr.chen # 实现简单的shell命令sed的替换功能 import ...

  3. Python运维开发基础08-文件基础【转】

    一,文件的其他打开模式 "+"表示可以同时读写某个文件: r+,可读写文件(可读:可写:可追加) w+,写读(不常用) a+,同a(不常用 "U"表示在读取时, ...

  4. Python运维开发基础04-语法基础【转】

    上节作业回顾(讲解+温习90分钟) #!/usr/bin/env python3 # -*- coding:utf-8 -*- # author:Mr.chen # 仅用列表+循环实现“简单的购物车程 ...

  5. Python运维开发基础01-语法基础【转】

    开篇导语 整个Python运维开发教学采用的是最新的3.5.2版,当遇到2.x和3.x版本的不同点时,会采取演示的方式,让同学们了解. 教学预计分为四大部分,Python开发基础,Python开发进阶 ...

  6. 重磅|0元学 Python运维开发,别再错过了

    51reboot 运维开发又双叒叕的搞活动了,鉴于之前 51reboot 的活动反馈,每次活动结束后(或者已经结束了很长时间)还有人在问活动的事情.这一次小编先声明一下真的不想在此次活动结束后再听到类 ...

  7. Python运维开发基础01-语法基础

    标签(空格分隔): Mr.chen之Python3.0执教笔记(QQ:215379068) --仅供北大青鸟内部学习交流使用 开发不是看出来的,开发一定是练出来的: 想学好开发,没有捷径可走,只有不断 ...

  8. Python运维开发基础10-函数基础【转】

    一,函数的非固定参数 1.1 默认参数 在定义形参的时候,提前给形参赋一个固定的值. #代码演示: def test(x,y=2): #形参里有一个默认参数 print (x) print (y) t ...

  9. Python运维开发基础07-文件基础【转】

    一,文件的基础操作 对文件操作的流程 [x] :打开文件,得到文件句柄并赋值给一个变量 [x] :通过句柄对文件进行操作 [x] :关闭文件 创建初始操作模板文件 [root@localhost sc ...

  10. Python运维开发基础06-语法基础【转】

    上节作业回顾 (讲解+温习120分钟) #!/usr/bin/env python3 # -*- coding:utf-8 -*- # author:Mr.chen # 添加商家入口和用户入口并实现物 ...

随机推荐

  1. 四月十五号java基础知识

    1.今天下午做了一个题感受很深,自己做题没有思路或者有点思路死磕也没有搞清楚,看起来很简单的问题,在我手里很难 做咯许久还是室友帮忙解决的,后面重新打一遍还是出问题,找他解决的,问了问他我自己的问题, ...

  2. ORA-17629: Cannot connect to the remote database server

    rman远程连接目标库,提示报错ORA-17629: Cannot connect to the remote database server,首先排查网络问题是否通路,结果发现目标端防火墙是开着的, ...

  3. day01-Redis入门

    Redis入门 1.初始Redis 1.1认识NoSQL SQL(关系型数据库) NoSQL(非关系型数据库) 数据结构 结构化(Structured) 非结构化 数据关联 关联的(Relationa ...

  4. TiDB与MySQL的SQL差异及执行计划简析

    作者:京东零售 肖勇 一. 前言导读 TiDB作为NewSQL,其在对MySQL(SQL92协议)的兼容上做了很多,MySQL作为当下使用较广的事务型数据库,在IT界尤其是互联网间使用广泛,那么对于开 ...

  5. React框架使用

    一:使用Vite创建React项目 二:React中组件使用 import React, { Component, useState } from "react"; //使用cla ...

  6. CSS 基础拾遗(核心知识、常见需求)

    本篇文章围绕了 CSS 的核心知识点和项目中常见的需求来展开.虽然行文偏长,但较基础,适合初级中级前端阅读,阅读的时候请适当跳过已经掌握的部分. 这篇文章断断续续写了比较久,也参考了许多优秀的文章,但 ...

  7. CentOS配置Django虚拟环境--坑点总结

    1.CentOS原装有python2.7,编译安装python3.X版本 2.sqlite-devel未安装 3.sqlite3版本过低报错 升级sqlite3版本 参考 https://blog.c ...

  8. SkyWalking的学习之一

    SkyWalking的学习之一 前言 最近在学习应用调优诊断等内容. 现在实际工作中实质上的拆分和微服务在售前阶段 所以真正用到链路的地方比较少. 但是人生都是要向前看的. 想着一方面提高自己. 一方 ...

  9. node 请求接口,返回大小限制

    请求Node端中转接口时,遇到以下异常: Request_fileSize_limit Request_fields_limit Request_fieldSize_limit 遇到以上异常时,调试信 ...

  10. 使用 Lambda 函数将 CloudWatch Log 中的日志归档到 S3 桶中

    > 作者:[SRE运维博客](https://www.cnsre.cn/) > 博客地址:[https://www.cnsre.cn/](https://www.cnsre.cn/) &g ...