Python基础之生成器、迭代器
一、字符串格式化进阶
Python的字符串格式化有两种方式: 百分号方式、format方式,由于百分号的方式相对来说比较老,在社区里讨论format方式有望取代百分号方式,下面我们分别介绍一下这两种方式:
1、百分号方式
用法:%[(name)][flags][width].[precision]typecode
(name):可选,用于选择指定的key
flags:可选,可提供选择的值有
1234+
#右对齐;正数前加正号,负数前加负号
-
#左对齐;正数前无符号,负数前加负号
空格
#右对齐;正数前加空格,负数前加负号
0
#右对齐;正数前无符号,负数前加负号;用0填充空白处
- width:可选,占有宽度
- .precision:可选,小数点后保留的位数
- typecode:必选123456789101112131415
s
#获取传入对象的__str__方法的返回值,并将其格式化到指定位置
r
#获取传入对象的__repr__方法的返回值,并将其格式化到指定位置
c
#整数:将数字转换成其unicode对应的值,10进制范围为 0 <= i <= 1114111(py27则只支持0-255);字符:将字符添加到指定位置
o
#将整数转换成 八 进制表示,并将其格式化到指定位置
x
#将整数转换成十六进制表示,并将其格式化到指定位置
d
#将整数、浮点数转换成 十 进制表示,并将其格式化到指定位置
e
#将整数、浮点数转换成科学计数法,并将其格式化到指定位置(小写e)
E
#将整数、浮点数转换成科学计数法,并将其格式化到指定位置(大写E)
f
#将整数、浮点数转换成浮点数表示,并将其格式化到指定位置(默认保留小数点后6位)
F
#同上
g
#自动调整将整数、浮点数转换成 浮点型或科学计数法表示(超过6位数用科学计数法),并将其格式化到指定位置(如果是科学计数则是e;)
G
#自动调整将整数、浮点数转换成 浮点型或科学计数法表示(超过6位数用科学计数法),并将其格式化到指定位置(如果是科学计数则是E;)
%
#当字符串中存在格式化标志时,需要用 %%表示一个百分号
注:Python中百分号格式化是不存在自动将整数转换成二进制表示的方式
百分号具体使用方法:
1
2
3
4
|
msg = ( 'hello %s,age %d' ) % ( 'jack' , 18 ) #根据顺序进行传值 msg = ( "my name %(name)s,age %(age)d" ) % ({ "name" : "jack" , "age" : 18 }) #根据定义的名字进行传值 msg = 'age %.2f' % ( 1.232323 ) #保留两位小数点 msg = 'age %.2f %%' % ( 1.23232 ) #这里必须注意要添加两个%号,输出百分比 |
2、Format方式
用法:[[fill]align][sign][#][0][width][,][.precision][type]
fill:空白处填充的字符
align:对齐方式(需配合width使用)
1234<
#内容左对齐
>
#内容右对齐(默认)
=
#内容右对齐,将符号放置在填充字符的左侧,且只对数字类型有效,符号+填充符+数字
^
#内容居中
- sign:有无符号数字123
+
#正号加正,负号加负
-
#正号不变,负号加负
空格
#正号加空格,负号加负
- #:对于二进制、八进制、十六进制,如果加上#,会显示0b/0o/0x,否则不显示
- ,:为数字添加分隔符,如:1,000,000
- width:格式化位所占用的宽度
- .precision:小数点保留精度
- type:格式化类型123456789101112131415161718
#传入” 字符串类型 “的参数
s
#格式化字符串类型数据
空白
#未指定类型,则默认是None,同s
#传入“ 整数类型 ”的参数
b
#将10进制整数自动转换成2进制表示然后格式化
c
#将10进制整数自动转换为其对应的unicode字符
d
#十进制整数
o
#将10进制整数自动转换成8进制表示然后格式化;
x
#将10进制整数自动转换成16进制表示然后格式化(小写x)
X
#将10进制整数自动转换成16进制表示然后格式化(大写X)
#传入“ 浮点型或小数类型 ”的参数
e
#转换为科学计数法(小写e)表示,然后格式化;
E
#转换为科学计数法(大写E)表示,然后格式化;
f
#转换为浮点型(默认小数点后保留6位)表示,然后格式化;
F
#转换为浮点型(默认小数点后保留6位)表示,然后格式化;
g
#自动在e和f中切换
G
#自动在E和F中切换
%
#显示百分比(默认显示小数点后6位)
format具体使用用法:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
tp1 = "i am {},age {},{}" . format ( 'six' , 18 , 'jack' ) #可以接受任意的数值类型 tp1 = "i am {},age {},{}" . format ( * [ 'six' , 18 , 'jack' ]) #加*将列表里的值一个一个传进去 tp1 = "i am {0},age {1},{0}" . format ( 'six' , 18 , 'jack' ) #根据下标进行赋值 tp1 = "i am {name},age {age},{name}" . format (name ='jack ' ,age = 18 ) #根据定义的名字进行传值
#format是字符串的一个方法,也就是一个函数,函数在传入字典是需要在前面加上**,类似**kwargs tp1 = "i am {:s},age {:d},{:f}" . format ( 'jack' , 18 , 1.34 ) #定义为:s,:d,:f,这里的值必须是字符串,数值,和浮点数 tp1 = "i am {name:s},age {age:d},{a:f}" . format ( * * { 'name' : 'jack' , 'age' : 18 , 'a' : 2.343 }) #定义名字 tp1 = "i am {name:s},age {age:d},{a:.2%}" . format ( * * { 'name' : 'jack' , 'age' : 19 , 'a' : 0.21312 }) #a:.2% 保留两位小数点,并且转换成百分比 tp1 = '{:#^20s}' . format ( '购物中心' ) #字符串居中 |
格式化操作就介绍到这里,更多的操作请参考官网:https://docs.python.org/3/library/string.html
二、递归
先通过一个小例子来认识一下递归的用法:
1
2
3
4
5
6
7
8
9
10
|
def func(n): n + = 1 #传入一个值自加1 if n > = 4 : #如果这个值大于等于4时,结束函数返回end return 'end' return func(n) ret = func( 1 ) print (ret) #结果: end |
图画的丑了一些,根据这个图我们来介绍一下递归,首先给函数赋值为1,当1进入函数后自加1,这是n=2,不满足n>=4的条件,将n=2传入return func()
进入第二次判断,同样没有满足条件,今天第三次判断这是n=3+1满足条件直接返回end,总结就是条件不满足就一直一层一层到递归下去,知道条件成立。
下面再举一个例子,咱们来算一下数字的阶乘:
1
2
3
4
5
6
7
8
9
|
def jiecheng(n): if n = = 1 or n = = 0 : return 1 return n * jiecheng(n - 1 ) ret = jiecheng( 5 ) print (ret) 结果: 120 |
三、迭代器、生成器
1、迭代器
迭代器是访问集合元素的一种方式。迭代器对象从集合的第一个元素开始访问,知道所有元素被访问完结束。迭代器只能往前不会后退,不过这也没什么,因为人们很少在迭代途中往后退。
迭代器的优点就是不要求事先准备好整个迭代过程中所有的元素,迭代器仅仅在迭代到某个元素时才计算元素,而在这之前或之后,元素可以不存在或者被销毁,这个特点使得它特别适合用于遍历一些巨大的或者无限的集合,比如几个G的文件
特点:
访问者不需要关心迭代器内部的结构,仅需要通过next()方法不断去取一下内容
不能随机访问集合中的某个值,只能从头到尾依次访问
访问到一半时不能后退
便于循环比较大的数据集合,节省内存
1
2
3
4
5
6
7
8
9
|
li = [ 11 , 22 , 33 , 44 ] a = filter ( lambda x:x> 22 ,li) print (a) 结果: < filter object at 0x0000024AACFD52E8 > #迭代器 print (a.__next__()) 33 |
2、生成器
一个函数调用时返回一个迭代器,那这个函数就叫生成器(generator);如果函数中包含yield语法,那这个函数就会变成生成器。
1
2
3
4
5
6
7
8
|
def func(): yield 1 #有yield的函数为生成器 yield 2 yield 3 ret = func() for i in ret: #进入函数找到yield,获取yield后面的数据 print (i) |
3、迭代器、生成器结合使用
1
2
3
4
5
6
7
8
9
10
11
|
def myrange(arg): #自己定义一个生成器接收一个参数,初始值为1,循环加值 start = 1 while True : if start >arg: return yield start start + = 1 ret = myrange( 3 ) for i in ret: print (i) |
四、补充双层装饰器
通过一个登录接口的例子,学习一下双层装饰器:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
|
#!/usr/bin/env python # -*- coding: utf-8 -*- #Author:HaiFeng Di USER_INFO = {} def check_login(func): def inner( * args, * * kwargs): if USER_INFO.get( 'is_login' , None ): ret = func( * args, * kwargs) return ret else : print ( '请登录!' ) return inner def check_admin(func): def inner( * args, * * kwargs): if USER_INFO.get( 'user_type' , None ) = = 2 : ret = func( * args, * kwargs) return ret else : print ( '无权限查看' ) return inner @check_login @check_admin def index(): print ( 'idnex' ) @check_login def home(): print ( 'home' ) def login(): name = input ( '请输入用户名:' ) if name = = 'admin' : USER_INFO[ 'is_login' ] = True USER_INFO[ 'user_type' ] = 2 else : USER_INFO[ 'is_login' ] = True USER_INFO[ 'user_type' ] = 1 def main(): while True : inp = input ( '1、登录;2、查看信息;3、超级管理员 \n >>>' ) if inp = = '1' : login() elif inp = = '2' : home() elif inp = = '3' : index() main() |
下面解释一下什么的程序执行步骤:
根据Python解释器从上而下的原则,先将check_login、check_admin两个函数写到内存中,然后解释器会先解释check_admin和index(),这时index已经是新的函数体为check_admin里的inner()函数,
然后又在外面加了一层装饰器check_login,这时check_login函数里的参数func是新函数index(即:check_admin里的inner),程序执行过程请看下图:
这次拾遗主要介绍了,字符串的高级用法,递归,生成器、迭代器和双层装饰器,后续会继续有一些类似的拾遗博客,主要是对一些扩展知识点的整理。
Python基础之生成器、迭代器的更多相关文章
- python基础(八)生成器,迭代器,装饰器,递归
生成器 在函数中使用yield关键字就会将一个普通的函数变成一个生成器(generator),普通的函数只能使用return来退出函数,而不执行return之后的代码.而生成器可以使用调用一个next ...
- python基础之生成器迭代器
1 生成器: 为什么要有生成器? 就拿列表来说吧,假如我们要创建一个list,这个list要求格式为:[1,4,9,16,25,36……]这么一直持续下去,直到有了一万个元素的时候为止.如果我们要创建 ...
- python高级之生成器&迭代器
python高级之生成器&迭代器 本机内容 概念梳理 容器 可迭代对象 迭代器 for循环内部实现 生成器 1.概念梳理 容器(container):多个元素组织在一起的数据结构 可迭代对象( ...
- 第三篇:python高级之生成器&迭代器
python高级之生成器&迭代器 python高级之生成器&迭代器 本机内容 概念梳理 容器 可迭代对象 迭代器 for循环内部实现 生成器 1.概念梳理 容器(container ...
- 十三. Python基础(13)--生成器进阶
十三. Python基础(13)--生成器进阶 1 ● send()方法 generator.send(value) Resumes the execution, and "sends&qu ...
- 十二. Python基础(12)--生成器
十二. Python基础(12)--生成器 1 ● 可迭代对象(iterable) An object capable of returning its members one at a time. ...
- 【笔记】Python基础四:迭代器和生成器
一,迭代器协议和for循环工作机制 (一),迭代器协议 1,迭代器协议:对象必须提供一个next方法,执行该方法要么返回迭代中的下一项,要么就引起一个stopiteration异常,以终止迭代(只能往 ...
- python基础编程:生成器、迭代器、time模块、序列化模块、反序列化模块、日志模块
目录: 生成器 迭代器 模块 time 序列化 反序列化 日志 一.生成器 列表生成式: a = [1,2,3,3,4,5,6,7,8,9,10] a = [i+1 for i in a ] prin ...
- (转)python基础学习-----生成器和迭代器
在Python中,很多对象都是可以通过for语句来直接遍历的,例如list.string.dict等等,这些对象都可以被称为可迭代对象.至于说哪些对象是可以被迭代访问的,就要了解一下迭代器相关的知识了 ...
- python基础一 day13 迭代器
# 双下方法# print([1].__add__([2]))# print([1]+[2]) # 迭代器# l = [1,2,3]# 索引# 循环 for# for i in l:# i## for ...
随机推荐
- Behaviac 腾讯开源行为树 简介(给策划)
1.为什么使用BT FSM模型的优势之一是简单.但是FSMs需要用转换(Transition)连接状态(State),因此,状态(State)失去了模块性(Modularity). BT的主要优势之一 ...
- bzoj 1047: [HAOI2007]理想的正方形【单调队列】
没有复杂结构甚至不长但是写起来就很想死的代码类型 原理非常简单,就是用先用单调队列处理出mn1[i][j]表示i行的j到j+k-1列的最小值,mx1[i][j]表示i行的j到j+k-1列的最大值 然后 ...
- 慕课网JavaScript函数1-20 作业:函数的基础封装
1-20 作业 小伙伴们,掌握了JavaScript的语法.流程控制语句以及函数,接下来让我们运用所学知识完成如gif图所示的效果——计算自己出生那天是该年当中的第几天. gif效果图如下: 任务描述 ...
- RT-Thread 设备驱动-硬件定时器浅析与使用
RT-Thread 4.0.0 访问硬件定时器设备 应用程序通过 RT-Thread 提供的 I/O 设备管理接口来访问硬件定时器设备,相关接口如下所示: 函数 描述 rt_device_find() ...
- DotnetCore(1)尝鲜构建Web应用
在上篇文章中DotnetCore环境安装完成后,现在我们来尝试构建Web应用. 新建文件夹NetCoreWebDemo,并cd进入NetCoreWebDemo文件夹 同时Ctrl+shift按下快捷键 ...
- No task executor bean found for async processing: no bean of type TaskExecut
使用springcloud,添加异步方法后,调用异步成功,但有个 No task executor bean found for async processing: no bean of type T ...
- Font Awesome矢量图标
下载 font-awesome 文件夹到您的项目中. 在HTML的 <head> 中引用font-awesome.min.css. 可以将Font Awesome图标使用在几乎任何地方,只 ...
- ElementaryOS 0.4快速配置工具
使用方法: 终端执行 wget http://linux-1251056822.costj.myqcloud.com/elementary_config && bash element ...
- FFT学习及简单应用(一点点详细)
什么是FFT 既然打开了这篇博客,大家肯定都已经对FFT(Fast Fourier Transformation)有一点点了解了吧 FFT即为快速傅里叶变换,可以快速求卷积(当然不止这一些应用,但是我 ...
- C# 文件操作(摘抄)
——选自<c# 编程兵书>第11章 张志强 胡君 编著 11 文件操作概述 11.1 驱动器 在Windows操作系统中,存储介质统称为驱动器,硬盘由于可以划分为多个区域,每一个区域称为一 ...