6th-Python基础——集合、函数
1、集合
主要作用:
(1)去重
(2)关系测试,交集、差集difference()、并集union()、反向差集symmetric_difference()、子集issubset()、父集issuperset()
2、函数
定义:函数是指将一组语句的集合通过一个名字(函数名)封装起来,要想执行这个哈数,只需调用其函数名即可
函数特性:(1)减少重复代码
(2)使程序变的可扩展
(3)使程序变得易维护
语法:
def sayhi():#函数名 print("Hello, I am nobody!") sayhi() #调用函数
带参数函数
def calc(x, y): res = x**y return res c = calc(a, b) print(c)
函数参数与局部变量
形参:变量只有在被调用时才分配内存,调用结束即释放。只在函数内部有效;
实参:可以是常亮、变量、表达式、函数,无论是何种类型的量,在进行函数调用时,其都必须有确定的值,以便把这些值传送给形参。因此应预先用赋值,输入等办法使参数获得确定值。
def calc(x, y): res = x**y return res c = calc(a, b) print(c)
默认参数
比如网站注册用户,不填写的国籍信息默认为中国,就是通过默认参数
def stu_register(name, age, course, country="CN"):
关键参数
正常情况下,给函数传参数要按顺序,不想按顺序就可以用关键参数,只需制定参数名即可,关键参数必须放在位置参数之后。
stu_register(age=22,name='alex',course="python",)
非固定参数
若你的函数在定义时不确定用户想传入多少个参数,就可以使用非固定参数
def stu_register(name,age,*args):#*args会把多传入的参数编程一个元组形式 print(name,age,args) stu_register("Alex",22) #输出 #Alex 22()#后面这个()就是args,只是因为没传只,所以为空 stu_register("Jack",32,"CN","python") #输出 #Jack 32 ("CN", "python")
**kwargs
def stu_register(name,age,*args,**kwargs):#*kwargs 会把多传入的参数变成一个dict形式 print(name,age,args,kwargs) stu_register("Jack", 32, "CN","Python",sex="Male",province="ShanDong")
局部变量
name = "Alex Li" def change_name(name): print("before change:",name) name = "a man has Tesla"#局部变量 print("after change", name)
全局与局部变量
在子程序中定义的变量称为局部变量,在程序的一开始定义的变量称为全局变量。
全部变量作用域是整个程序,局部变量作用域是定义该变量的子程序。
当全局变量与局部变量同名:在定义局部变量的子程序内,局部变量起作用;在其他地方全局变量起作用。
返回值
想要获得函数的执行结果,就可以用return语句把结果返回
注意:
1、函数在执行过程中只要遇到return语句,就会停止执行并返回结果,so也可以理解为return语句代表着函数的结束;
2、如果未在函数中指定return,那这个函数的返回值为None。
嵌套函数
name = "Alex" def change_name(): name = "Alex2" def change_name2(): name = "Alex3" print("第3层打印",name) change_name2() print("第2层打印",name) change_name() print("最外层打印",name)
此函数调用出错
递归
在函数内部,可以调用其他函数。如果一个函数在内部调用自身本身,这个函数就是递归函数。
def calc(n): print(n) if int(n/2) == 0: return n return calc(int(n/2)) calc(10)
递归特性:
1、必须有一个明确的结束条件
2、每次进入更深一层递归时,问题规模相比上次递归都应有减少
3、递归效率不高,递归层次过多会导致栈溢出(在计算机中,函数调用时通过栈(stack)这种数据结构实现的,每当进入一个函数调用,栈就会加一层栈帧,每当函数返回,栈就会减一层栈帧。由于栈的大小不是无限的,所以,递归调用的次数过多,会导致栈溢出)
堆栈扫盲http://www.cnblogs.com/lln7777/archive/2012/03/14/2396164.html
匿名函数
匿名函数就是不需要显示的指定函数
def calc(n): return n**n print(calc(10)) clac = lambda n:n*n print(calc(10))
匿名函数主要是和其他函数搭配使用,例如
res = map(lambda x:x**2,[1,5,7,4,8]) for i in res: print(i)
函数式编程
函数式编程中的函数这个术语不是指计算机中的函数(实际上是Subroutine),而是指数学中的函数,即自变量的映射。也就是说一个函数的值仅决定于函数参数的值,不依赖其他状态。比如sqrt(x)函数计算x的平方根,只要x不变,不论什么时候调用,调用几次,值都是不变的。
Erlang,Haskell
高阶函数
变量可以指向函数,函数的参数能接收变量,那么一个函数就可以接收另一个函数作为参数,这种函数就称之为高阶函数。
def add(x, y , f): return f(x) + f(y) res = add(3,-6,abs) print(res)
内置参数
内置参数详解 https://docs.python.org/3/library/functions.html?highlight=built#ascii
6th-Python基础——集合、函数的更多相关文章
- python基础——匿名函数
python基础——匿名函数 当我们在传入函数时,有些时候,不需要显式地定义函数,直接传入匿名函数更方便. 在Python中,对匿名函数提供了有限支持.还是以map()函数为例,计算f(x)=x2时 ...
- python基础——返回函数
python基础——返回函数 函数作为返回值 高阶函数除了可以接受函数作为参数外,还可以把函数作为结果值返回. 我们来实现一个可变参数的求和.通常情况下,求和的函数是这样定义的: def calc_ ...
- python基础——sorted()函数
python基础——sorted()函数 排序算法 排序也是在程序中经常用到的算法.无论使用冒泡排序还是快速排序,排序的核心是比较两个元素的大小.如果是数字,我们可以直接比较,但如果是字符串或者两个d ...
- python基础——filter函数
python基础——filter函数 Python内建的filter()函数用于过滤序列. 和map()类似,filter()也接收一个函数和一个序列.和map()不同的是,filter()把传入的函 ...
- python基础——匿名函数及递归函数
python基础--匿名函数及递归函数 1 匿名函数语法 匿名函数lambda x: x * x实际上就是: def f(x): return x * x 关键字lambda表示匿名函数,冒号前面的x ...
- 八. Python基础(8)--函数
八. Python基础(8)--函数 1 ● 函数返回布尔值 注意, 自定义的函数也可以是用来作逻辑判断的, 例如内置的startswith()等函数. def check_len(x): ' ...
- python基础之函数详解
Python基础之函数详解 目录 Python基础之函数详解 一.函数的定义 二.函数的调用 三.函数返回值 四.函数的参数 4.1 位置参数 4.2 关键字参数 实参:位置实参和关键字参数的混合使用 ...
- Python学习笔记(一)python基础与函数
1.python基础 1.1输入与输出 输出 用print加上字符串,就可以打印指定的文字或数字 >>> print 'hello, world' hello, world > ...
- Day3 - Python基础3 函数、递归、内置函数
Python之路,Day3 - Python基础3 本节内容 1. 函数基本语法及特性 2. 参数与局部变量 3. 返回值 嵌套函数 4.递归 5.匿名函数 6.函数式编程介绍 7.高阶函数 8. ...
- Python基础__函数
本节将进入函数的介绍,函数是Python基础中最精彩的部分之一,接下来将对函数做详细介绍.函数 函数就是对代码进行一个封装.把实现某一功能的代码进行封装到一起.下次需要使用时不需要进行编写代码直接调用 ...
随机推荐
- Water Buying
Water Buying time limit per test 1 second memory limit per test 256 megabytes input standard input o ...
- C++ 中文拼音排序方法。
参考文档:http://zisxks.com/2013/10/25/sort-Chinese-characters-in-cpp/ 采用locate.注意事项:排序的名字,如果出现某一个人,出现在顶上 ...
- jQuery 基本选择器 层次选择器 过滤选择器 内容过滤选择器 可见过滤选择器 属性过滤选择器 表单对象属性过滤选择器
- HTML、CSS知识点,面试开发都会需要--No.5 文章段落
No.5 文章段落 1.文字属性 文字属性包含font-*和text-*两类. 2.基于font的属性 (1)font-family:字体属性,多个字体之前用逗号隔开.如果第一个字体没找到,则依次找后 ...
- 队列模拟基本操作I
看到这道题,第一个想法就是“搜索”!“回溯”!的确,这种思路是很正确的,BFS和DFS都可以来解决: #include <cstdlib> #include <cstring> ...
- stm32f7699遇到的犯二问题
没有看到stlink的驱动,难道板子坏了?? 结果:USB线的问题,换了一根用过的线,就行了:
- JDBC事务(三)ThreadLocal绑定Connection
处理一个请求即开启一个线程,在三层中,执行三层中的方法都是用的同一个线程. 我们开启一个事务,使用conn.setAutoCommit(false); conn应该属于ado层,不应该出现在servi ...
- mixpanel umeng talkingdata
市面上可以比较容易的接触到的实时大数据用户行为分析系统有很多,比如国外有著名的Mixpanel.Localytics.Google,国内有TalkingData.这些公司都提供基于云的大数据分析系统, ...
- Java并发问题--乐观锁与悲观锁以及乐观锁的一种实现方式-CAS
首先介绍一些乐观锁与悲观锁: 悲观锁:总是假设最坏的情况,每次去拿数据的时候都认为别人会修改,所以每次在拿数据的时候都会上锁,这样别人想拿这个数据就会阻塞直到它拿到锁.传统的关系型数据库里边就用到了很 ...
- 【LeetCode每天一题】Word Search(搜索单词)
Given a 2D board and a word, find if the word exists in the grid.The word can be constructed from le ...