Python进阶【第四篇】函数
一、变量
变量是记录一系列状态变化的量
1.变量分为可变类型与不可变类型——可变 与不可变是根据变量在内存中占据的位置
可变类型:列表list[ ]、字典dicta{ }
不可变类型:字符串str、数字int、元组()
2.按照访问方式可分为顺序访问、映射访问和直接访问
直接访问:数字int
映射访问:字典dict{ }
顺序访问:字符串str、列表list[ ]、元组()
二、集合
特征:由不同的元素组成,元素无序,集合中的元素必须是不可变类型
1.集合定义:set()
s = set('hello')
print(s)
#输出结果为{'o','h','l','e'},无序,无重
其中()中必须为可迭代类型
2.常用方法
- 添加元素
add() #向集合中添加元素
- 清空集合
clear() #清空集合
- 删除集合中的元素
pop()#随机删除某个元素
remove()#指定某个值删除,当不存在要删除的元素时,编译报错
discard()#指定某个值删除,当不存在要删除的元素时,编译不报错
3.常用操作
- 求交集
s1.intersection(s2) #求s1与s2的交集
- 求并集
s1.union(s2) #求s1与s2的并集
- 求差集
s1.difference(s2) #s1中有,s2中没有的元素 s2.difference(s1) #反之
- 判断
s1.difference_update(s2) #等价于s1 = s1-s2 s1.isdisjoint(s2) #交集是否为空集 s1.issubset(s2) #s1是否为s2的子集,反之,issuperset()判断是否为父集
三、字符串格式化
%s固定类型,用于传值,传多个值是(,,,),中间用逗号分隔
%d——传数字,%s——可用于传一切数据类型
打印浮点数:
%.2f #打印小数点后2位
打印百分号:%%
字典的传值:
%(name)d %(age)s #传一个字典,key=name,key=age
四、函数
形式:
def test()
关键字 函数名 形参
代码块
return
返回值
函数的定义主要有如下要点:
- def:表示函数的关键字
- 函数名:函数的名称,日后根据函数名调用函数
- 函数体:函数中进行一系列的逻辑计算,如:发送邮件、计算出 [11,22,38,888,2]中的最大数等...
- 参数:为函数体提供数据
- 返回值:当函数执行完毕后,可以给调用者返回数据。
关于返回值:
- 无返回值:返回一个None
- 有一个返回值:返回object
- 多个返回值:返回一个tuple
函数的有三中不同的参数:
- 普通参数
- 默认参数
- 动态参数
# ######### 定义函数 ######### # name 叫做函数func的形式参数,简称:形参
def func(name):
print name # ######### 执行函数 #########
# 'wupeiqi' 叫做函数func的实际参数,简称:实参
func('无名') 普通参数
def func(name, age = 18): print "%s:%s" %(name,age) # 指定参数
func('无名', 19)
# 使用默认参数
func('有名') 注:默认参数需要放在参数列表最后 默认参数
参数的传值时位置参数,关键字参数的使用规则:
- 位置参数必须一一对应,缺一不行,多一也不行
- 一个参数不能传两个值
- 若位置参数与关键字参数混合使用,则位置参数必须在关键字参数左边
- 多组参数(位置参数,*args,**kwargs)对应形式为(位置参数,列表,字典)
五、局部变量与全局变量
局部变量;在子程序中定义的变量
全局变量;在整个文件中任何位置均可调用到
变量使用的就近原则
关于global关键字:
如果函数中无global关键字,优先读取局部变量,若无局部变量,则只能读取全局变量,也就无法对其赋值或者修改。
当有global关键字时,global把全局变量拿到函数中,变成了该函数的变量,但对其他函数来讲,仍然是全局变量,但全局变量的值可以在上一个函数中被修改。
为了以后避免变量重名问题,全局变量一律大写,局部变量小写。
函数执行顺序
六、递归
函数自己调用自己,但必须有个明确的结束条件。
在函数内部,可以调用其他函数。如果一个函数在内部调用自身本身,这个函数就是递归函数。
举个例子,我们来计算阶乘n! = 1 x 2 x 3 x ... x n,用函数fact(n)表示,可以看出:
fact(n) = n! = 1 x 2 x 3 x ... x (n-1) x n = (n-1)! x n = fact(n-1) x n
所以,fact(n)可以表示为n x fact(n-1),只有n=1时需要特殊处理。
于是,fact(n)用递归的方式写出来就是:
def fact(n):
if n==1:
return 1
return n * fact(n - 1)
递归函数的优点是定义简单,逻辑清晰。理论上,所有的递归函数都可以写成循环的方式,但循环的逻辑不如递归清晰。
使用递归函数需要注意防止栈溢出。在计算机中,函数调用是通过栈(stack)这种数据结构实现的,每当进入一个函数调用,栈就会加一层栈帧,每当函数返回,栈就会减一层栈帧。由于栈的大小不是无限的,所以,递归调用的次数过多,会导致栈溢出。
解决递归调用栈溢出的方法是通过尾递归优化,事实上尾递归和循环的效果是一样的,所以,把循环看成是一种特殊的尾递归函数也是可以的。
尾递归是指,在函数返回的时候,调用自身本身,并且,return语句不能包含表达式。这样,编译器或者解释器就可以把尾递归做优化,使递归本身无论调用多少次,都只占用一个栈帧,不会出现栈溢出的情况。
尾递归调用时,如果做了优化,栈不会增长,因此,无论多少次调用也不会导致栈溢出
Python进阶【第四篇】函数的更多相关文章
- Python进阶----反射(四个方法),函数vs方法(模块types 与 instance()方法校验 ),双下方法的研究
Python进阶----反射(四个方法),函数vs方法(模块types 与 instance()方法校验 ),双下方法的研究 一丶反射 什么是反射: 反射的概念是由Smith在1982年首次提出的 ...
- Python进阶(十四)----空间角度研究类,类与类之间的关系
Python进阶(十四)----空间角度研究类,类与类之间的关系 一丶从空间角度研究类 对象操作对象属性 class A(): address = '沙河' def __init__(self, na ...
- Python进阶(五)----内置函数Ⅱ 和 闭包
Python进阶(五)----内置函数Ⅱ 和 闭包 一丶内置函数Ⅱ ####内置函数#### 特别重要,反复练习 ###print() 打印输入 #sep 设定分隔符 # end 默认是换行可以打印到 ...
- [Python笔记]第四篇:内置函数
本篇主要内容:内置函数 函数 参考:https://docs.python.org/3.5/library/functions.html 内置函数列表 一.数学运算类 abs(x)求绝对值 >& ...
- Python【第四篇】函数、内置函数、递归、装饰器、生成器和迭代器
一.函数 函数是指将一组语句的集合通过一个名字(函数名)封装起来,要想执行这个函数,只需调用其函数名即可 特性: 减少重复代码 使程序变的可扩展 使程序变得易维护 1.定义 def 函数名(参数): ...
- python开发第四篇:函数(1)
函数 阅读目录 一 函数知识体系 二 函数基础 三 函数对象.函数嵌套.名称空间与作用域.装饰器 四 迭代器.生成器.面向过程编程 五 三元表达式.列表推导式.生成器表达式.递归.匿名函数.内置函数 ...
- 【python自动化第四篇:python入门进阶】
今天的课程总结: 装饰器 迭代器&生成器 json&pickle实现数据的序列化 软件目录结构规范 一.装饰器 装饰器的本质是函数,起目的就是用来为其它函数增加附加功能 原则:不能修改 ...
- python基础-第四篇-4.1内置函数
lambda表达式 lambda表达式是对简单函数的精简化表达 语法结构:函数名 = lambda:运算表达式 def f1(a): a = a + 1 return a ret = f1(1) pr ...
- Python 学习 第四篇:动态类型模型
Python的变量不用声明,赋值之后就可以直接使用,类型是在运行过程中自动确定的,这就是动态类型模型.该模型把变量和对象设计成两个不同的实体,对象是存储数据的地方,对象的类型是由初始值自动决定的,而变 ...
- Python进阶【第二篇】编写Python代码
一.第一句Python代码——Hello Word 在 /home/dev/ 目录下创建 hello.py 文件,内容如下: print "hello,world" 执行 hell ...
随机推荐
- IOS 键盘弹出导致的position:fixed 无效问题
解决办法(还未测试): 只需要在中间部分外层div添加css样式position:fixed;top:50px; bottom:50px;overflow:scroll;就可以实现效果,无需插件.可拷 ...
- postman测试iop中url时的idtoken
记得填写 X-Auth-Token 对应cookies中的 token_id
- Java 基础 引用数据类型 和 流程控制
引用数据类型 与定义基本数据类型变量不同,引用数据类型的变量定义及复制有一个相对固定的步骤和格式: 数据类型 变量名 = new 数据类型(); 如:String st = new String(); ...
- 【Java】-NO.16.EBook.4.Java.1.009-【疯狂Java讲义第3版 李刚】- 泛型
1.0.0 Summary Tittle:[Java]-NO.16.EBook.4.Java.1.009-[疯狂Java讲义第3版 李刚]- 泛型 Style:EBook Series:Java Si ...
- 单点登录开源架构之CAS
服务端 开源地址:https://github.com/apereo/cas Release版:https://github.com/apereo/cas/releases Windows下使用下载c ...
- 从零开始一起学习SLAM | 神奇的单应矩阵
小白最近在看文献时总是碰到一个奇怪的词叫“homography matrix”,查看了翻译,一般都称作“单应矩阵”,更迷糊了.正所谓:“每个字都认识,连在一块却不认识”就是小白的内心独白.查了一下书上 ...
- cocos2d JS 错误异常抛出捕获和崩溃拦截
Error对象 一旦代码解析或运行时发生错误,JavaScript引擎就会自动产生并抛出一个Error对象的实例,然后整个程序就中断在发生错误的地方. Error对象的实例有三个最基本的属性: nam ...
- iOS - (多图上传已封装)
/*** 上传带图片的内容,允许多张图片上传(URL)POST** @param url 网络请求地址* @param images ...
- 下拉列表控件实例 ComboBoxControl
下拉列表控件实例 书:151页 <?xml version="1.0" encoding="utf-8"?> <s:Application x ...
- codeforces 980C Posterized
题意: 255个像素格子,可以把这个255个分组,每组的大小不能超过k. 给出n个像素,要求每个像素用这组的key代表,并且表示出来的字典序要最小. 思路: 感谢js教本智障. 很自然的会想到贪心,也 ...