13.4 文件上使用列表解析与列表解析扩展

这一章节我们来讨论一下文件上使用列表解析与列表解析扩展

1.文件上使用列表解析

在处理文件里面文本的时候,我们一般都会遇到比较麻烦的场景,,如:去除所有换行符,我们一般都会想到下面的办法

>>> hanlder=open('output_file.txt')>>> aList=[]>>> for line in hanlder:aList.append (line.rstrip())>>> aList['aaaaa', 'bbbbb', 'ccccc', 'ddddd', 'fffff']>>> 但是我们可以通过列表解析,简洁的处理上面的问题

>>> hanlder=open('output_file.txt')>>> bList=[line.rstrip () for line in hanlder]>>> bList['aaaaa', 'bbbbb', 'ccccc', 'ddddd', 'fffff']>>> hanlder.close ()>>> 在上面的方法里面其实我们也可以使用分片方法line[:-1],但是需要确定每一行文本的正确性

其实,第二种方法里面,python替我们做了很多隐含的工作,而且由于它是使用c语言操作,因此,它的运行速度比相同功能的python语句更快,更高效率

我们下面再举一些例子:

把字符串变成大写

>>> hanlder=open('output_file.txt')>>> bList=[line.rstrip ().upper() for line in hanlder]>>> bList['AAAAA', 'BBBBB', 'CCCCC', 'DDDDD', 'FFFFF']>>> hanlder.close ()

替换某些字符>>> hanlder=open('output_file.txt')>>> bList=[line.rstrip ().replace('a','T').upper() for line in hanlder]>>> bList['TTTTT', 'BBBBB', 'CCCCC', 'DDDDD', 'FFFFF']>>> hanlder.close ()>>> 2.扩展

1)我们沿用上面的txt文件,但是我们只需要输出带有a开头的句子

这里我们就需要在列表解析里面加上if的使用

>>> hanlder=open('output_file.txt')>>> bList=[line.rstrip () for line in hanlder if line[0]=='a']>>> bList['aaaaa', 'accccc', 'afffff']>>> hanlder.close ()>>> 2)使用多个列表解析

>>> [x+y for x in 'abc' for y in 'efg' ]['ae', 'af', 'ag', 'be', 'bf', 'bg', 'ce', 'cf', 'cg']>>> >>> [x+y for x in [1,2,3] for y in [3,4,5] ][4, 5, 6, 5, 6, 7, 6, 7, 8]>>> 上面我们同时解析两个序列,然后进行运算

我们还可以扩展到多个序列上面

>>> [x+y+z for x in [1,2,3] for y in [3,4,5] for z in [6,7,8]][10, 11, 12, 11, 12, 13, 12, 13, 14, 11, 12, 13, 12, 13, 14, 13, 14, 15, 12, 13, 14, 13, 14, 15, 14, 15, 16]>>>

>>> for x in [1,2,3]:for y in [3,4,5]:for z in [6,7,8]:print(x+y+z,end=',')10,11,12,11,12,13,12,13,14,11,12,13,12,13,14,13,14,15,12,13,14,13,14,15,14,15,16,>>> 其实上面的代码实现了多重循环的嵌套,然后形成新的列表

总结:这一章节我们讨论了文件上面使用列表解析,以及列表解析的扩展

这一章节就说到这里,谢谢大家

——————————————————————

点击跳转零基础学python-目录

版权声明:本文为博主原创文章,未经博主允许不得转载。

纵然伤心,也不要愁眉不展,因为你不知是谁会爱上你的笑容

13.4 文件上使用列表解析与列表解析扩展

相关文章:

你感兴趣的文章:

标签云: