Python3学习(二)-递归函数、高级特性、切片
##import sys
##sys.setrecursionlimit(1000)
###关键字参数(**关键字参数名)
###与可变参数不同的是,关键字参数可以在调用函数时,传入带有参数名的参数,这些参数会自动组装成一个
###dict,参数名为key,参数值为value
##def person(name,age,**kv):
## print('name',name,'age',age,'关键字参数',kv)
##person('jian',18,tell=174,weight=71)#name jian age 18 关键字参数 {'tell': 174, 'weight': 71}
###可见,关键字参数可以传入一些非必要的参数,扩展功能。
###也可以像可能参数的函数一样,把参数组装成一个dict,然后传进去。
##extra = {'city':'Beijing','job':'Engineer'}
##person('jian',19,**extra)#name jian age 19 关键字参数 {'city': 'Beijing', 'job': 'Engineer'} ###命名关键字参数(*,参数名1,2......),用'*'号作为分隔符。
###在关键字参数的基础上,如果要指定传入参数的名称,则要用命名关键字参数,在*,后写参数名
##def person1(name,age,*,job,like):
## print(name,age,job,like)
##person1('jian',18,job='bianchen',like='play')#jian 18 bianchen play
###person1('jian',18,like='play')#TypeError: person1() missing 1 required keyword-only argument: 'job'
###上面一行报错,说明命名关键字参数的每个参数都要传入参数值,但参数的位置可以不固定。如:
##person1('jianweiwei',19,like='play',job='learn')#jianweiwei 19 learn play.
###如果命名关键字参数有默认值则可以不用传参数。 ###参数定义顺序
###python中可变参数不可以和命名关键字参数混合使用,参数定义的顺序是:必选参数、默认参数、可变参数/命名关键字参数和关键字参数
##def f1(a,b,c=0,*args,**kw):
## print('a=',a,'b=',b,'c=',c,'args=',args,'kw=',kw)
##def f2(a,b,c=0,*,d,**kw):
## print('a=',a,'b=',b,'c=',c,'d=',d,'kw=',kw)
###在函数调用时,Python解释器自动按照参数位置和参数名把对应的参数传进去。
##f1('我是a','我是b','我是c','1',2,3,4,{'name':'jian','age':13})
###打印结果a= 我是a b= 我是b c= 我是c args= ('1', 2, 3, 4, {'age': 13, 'name': 'jian'}) kw= {}
###可以看到,关键字参数为空的字典,可变参数为一个元组,那么怎么把列表传给关键字参数,而不是可变参数呢。
##mm = {'name':'jian','age':13}
##f1('我是a','我是b','我是c','1',2,3,4,**mm)#a= 我是a b= 我是b c= 我是c args= ('1', 2, 3, 4) kw= {'age': 13, 'name': 'jian'}
###可以看到结果,可变参数,组都有数据了,就是通过指定传入的参数类型,在前面加上*,或**,来区别可变函数与关键字参数 ###参数小结:
###默认参数一定不是可变参数,如果是可变参数,会造成逻辑错误,如
##def a1(a,b,c=8):
## print(a,b,c)
###上面默认参数指向不可变参数8,这样写正确。
##def a2(a,b,c=[]):
## print(a,b,c)
###上面默认参数指向为可变的list,写法错误。 ####递归函数
###在函数内部,可以调用其他函数,如果一个函数在内部调用自身本身,这个函数就是递归函数。
##def fact(n):
## if n==1:
## return 1
## return n*fact(n-1)#这里不是尾递归,返回引入了乘法表达式。
##a = fact
##print(a(10))
###在测试输入参数值1000时会导入栈溢出,此时通过尾递归优化,事实上尾递归和循环的效果是一样的。可以把
###循环看作是尾递归的一种。
###尾递归是指:在函数返回的时候,调用自身本身,每一步的乘积传入到递归函数中:
##def fact1(n):
## return fact_iter(n,1)
##def fact_iter(num,product):
## if num == 1:
## return product
## return fact_iter(num-1,num*product)
##print(fact1(1000))#作者好坑,原来最后才说python也没有做栈优化,我说怎么老是溢出错误。 #练习
#尼麻啊,我不会555555555555555555 #高级特性:就是实现相同的功能,写的代码越少越好。
##L = []
##i = 1
##while i<=9:
## L.append(i)
## i = i+1
## print(L) ##切片
#所谓的切片有点像java里的截取。无论正序还是倒序,下标第一个都是0,或-0.
#第一冒号前后的数据是用来
L = [1,3,4,5,2,3,4,5,6,67,77,22,33,444,2222,777]
#切前3个下来
print(L[0:3])
print(L[0:4])#前四个
#也可以每隔2个切一个
print(L[::2])#
#从切取的范围中每隔3个切一个
print(L[-6:-2:2])#[77, 33],指从倒数下标为-6切到下标为-2,再每次隔2个切一个。
#字符串也能切片,但切片应该是重新创建一个新的字符串,而不是直接切原来的字符串,因为字符串是不可变的
#元组切片是生成一个新的元组。 ##迭代:对list或tuple的遍历称为迭代。
Python3学习(二)-递归函数、高级特性、切片的更多相关文章
- Python高级特性(切片,迭代,列表生成式,生成器,迭代器)
掌握了Python的数据类型.语句和函数,基本上就可以编写出很多有用的程序了. 比如构造一个1, 3, 5, 7, ..., 99的列表,可以通过循环实现: L = [] n = 1 while n ...
- Spring框架学习[IoC容器高级特性]
1.通过前面4篇文章对Spring IoC容器的源码分析,我们已经基本上了解了Spring IoC容器对Bean定义资源的定位.读入和解析过程,同时也清楚了当用户通过getBean方法向IoC容器获取 ...
- 深入浅出Redis(二)高级特性:事务
第一篇中介绍了Redis是一个强大的键-值仓储,支持五种灵活的数据结构.其实,Redis还支持其他的一些高级特性:事务.公布与订阅.管道.脚本等,本篇我们来看一下事务. 前一篇中我们提到,在Redis ...
- Python学习笔记(二)——高级特性
知识点 切片 切片 取一个list或tuple的部分元素. 原理:调用__getitem__,__setitem__,__delitem__和slice函数. 根据官方的帮助文档(https://do ...
- 【Python学习之五】高级特性1(切片、迭代、列表生成器、生成器、迭代器)
1.切片 有一个list—>L = [1,2,3,4,5,6,7]或tuple—>T = (1,2,3,4,5,6,7),如果想取得前三个元素,怎么操作? 硬方法,也是低效的方法是:L= ...
- 【Python学习之五】高级特性5(切片、迭代、列表生成器、生成器、迭代器)
5.迭代器 由之前的生成器可知,for循环用于可迭代对象:Iterable.包括集合数据类型: list.tuple.dict.set.str 等,以及两种生成器.判断迭代器,使用 isinstanc ...
- 【Python学习之五】高级特性4(切片、迭代、列表生成器、生成器、迭代器)
4.生成器(generator) 通过列表生成式,我们可以直接创建一个列表.但是,受到内存限制,列表容量肯定是有限的.如果列表元素可以按照某种算法推算出来,那我们是否可以在循环的过程中不断推算出后续的 ...
- 【Python学习之五】高级特性3(切片、迭代、列表生成器、生成器、迭代器)
3.列表生成器(List Comprehensions) 列表生成式即List Comprehensions,是Python内置的非常简单却强大的可以用来创建list的生成式.举个例子,要生成list ...
- 【Python学习之五】高级特性2(切片、迭代、列表生成器、生成器、迭代器)
2.迭代 如果给定一个list或tuple,我们可以通过for循环来遍历这个list或tuple,这种遍历我们称为迭代(Iteration).在Python中,迭代是通过for ... in来完成的. ...
- Scala学习(二)——高级特性
apply() 方法 apply方法是Scala提供的一个语法糖 类名+括号,调用对象的apply方法 对象名+括号,调用类的apply方法 对apply方法的简单测试:(其中,带 new -- cl ...
随机推荐
- OpenCV2+入门系列(三):遍历图像的几种方法
根据OpenCV中Mat类型的结构和内存中存储方式,此处给出三种对图像进行遍历的方法.首先给出基础的读取图片代码,在中间替换三种遍历方法即可,本文中,程序将遍历图像并将所有像素点置为255,所有运行结 ...
- unreal 自定义 Slate Style Sets
搜集到的最有价值的一篇教学,按照作者的方法尝试中遇到了一些问题.[感谢这位作者!] 网址:https://wiki.unrealengine.com/Slate_Style_Sets_Part_2 在 ...
- .Net环境下的缓存技术介绍
.Net环境下的缓存技术介绍 摘要: 介绍缓存的基本概念和常用的缓存技术,给出了各种技术的实现机制的简单介绍和适用范围说明,以及设计缓存方案应该考虑的问题(共17页) 1 概念 1.1 ...
- SignalR
https://msdn.microsoft.com/zh-cn/magazine/dn802609.aspx http://www.asp.net/signalr/overview/getting- ...
- Nodejs学习总结 -Express入门(一)
Express是基于Node.js平台开发的Web应用开发框架,下面我们入手学习. 官网 : http://www.expressjs.com.cn/ github:https://github.co ...
- Java多线程初探
多线程 单线程的程序只有一个顺序执行流.多个顺序流之间互不干扰. 多线程的创建 定义Thread类的子类,重写该类的run()方法. 创建Thread子类的实例. 调用线程对象的start()方法来启 ...
- js流程控制题——如何实现一个LazyMan
先说一下想要的效果: lazyMan('zz').eat('lunch').sleep('3').eat('dinner')输出: Hi!This is zz! Eat lunch~ //有3s间隔等 ...
- 输入scanner,if-else
import java.util.Scanner; public class Job{ public static void main(String[] args){ Scanner scanner ...
- JS根据登录的城市不同调用不同的内容
这个思路就是通过js获取访问客户的IP地址,根据IP接口判断IP的所属城市 1.先引入ip接口的js文件,网上有很多,这里用的是新浪的(感谢新浪) <script type="text ...
- Sphinx Search 学习 (一)
参考资料一:(中文)http://www.coreseek.cn/docs/coreseek_3.2-sphinx_0.9.9.html (官方)http://sphinxsearch.com/doc ...