从一个例子看Python3.x中序列解包
来源:互联网 发布:企业名录数据库 编辑:程序博客网 时间:2024/05/17 11:56
假如一个字符串'ABCDEFGH',要输出下列格式:
即: 每次取出第一个作为首,然后的字符串拆成列表,放置在后面,最后成上面的输出:
一般的处理是:
>>> s = 'ABCDEFGH'>>> while s: front, s = s[0], list(s[1:]) print(front, s)A ['B', 'C', 'D', 'E', 'F', 'G', 'H']B ['C', 'D', 'E', 'F', 'G', 'H']C ['D', 'E', 'F', 'G', 'H']D ['E', 'F', 'G', 'H']E ['F', 'G', 'H']F ['G', 'H']G ['H']H []备注:
1.将切片中索引为0的字符赋值给front
2.将切片中索引为1之后字符再赋值给s
3.用list函数将字符串转变为列表
4.用while循环来s来判断,为空,则退出循环
上面的处理,可以用序列解包的方法会来处理,并好理解。 序列解包是Python 3.0之后出现,之前的版本一般赋值的时候,一定要对等,才能正常赋值,比如说:
>>> a, b, c = (1, 2, 3)>>> a, c(1, 3)>>> [a, b, c] = (1, 2, 3)>>> a, c(1, 3)>>> a, b, c = 'SON' # 刚好三个字符的字符串>>> a, c('S', 'N')如果是不对等的情况下,是会报错的: too many values to unpack
>>> a, b = 'SON'Traceback (most recent call last): File "<pyshell#42>", line 1, in <module> a, b = 'SON'ValueError: too many values to unpack (expected 2)3.0出现了解包,一切就简单多了,如果我不之后字符有多少个时候,都可以如此:
>>> a, *b = 'BOOK'>>> a, b('B', ['O', 'O', 'K'])>>> *a, b = 'BOOK'>>> a, b(['B', 'O', 'O'], 'K')
上面就是序列解包,在赋值时无疑更方便,适用性更强!运用序列解包的功能重写上面的代码:
从上面可以看出: 代码更简洁,也更好理解了!
阅读全文
0 0
- 从一个例子看Python3.x中序列解包
- 从一个TCP抓包的例子看流量整形-概述
- 从一个例子看WML文档规则
- 从一个例子看内存布局
- 从一个例子看网站发展过程
- 看JAVA序列化的性能 -- 一个简单的例子
- python3.x中urllib和urllib2包的更新
- 从一个失败的例子看dojo widget的定制
- 从例子看数据结构
- python 3.x中列表排序问题,从python2.x过渡到python3.x
- 从com聚合中 举一个 例子
- 从一个小例子再次理解闭包
- python3.x 的urllib使用例子
- python3.x 的urllib使用例子
- python3.x 的urllib使用例子
- 从例子看C++模版
- 从例子看C++模版
- 从例子中学习闭包和范式for
- OpenCV:Python3使用OpenCV
- 数据结构入门——完全二叉树
- DOM-增加
- 找7,找12
- 自己写的unix文件拷贝指令cp实现函数
- 从一个例子看Python3.x中序列解包
- PHP数组缓存:三种方式JSON、序列化和var_export的比较
- [JAVA]反射机制按顺序获取getDeclaredFields()/getDeclaredMethods()
- 第11周项目5
- Centos 6.x grub 进入系统
- c#调用 Win32Api之错误处理
- 微服务在互联网公司演进过程
- 使用go写了一个简单ini解析器
- Redis之 集合(Sets)