本文摘自php中文网,作者不言,侵删。
这篇文章主要介绍了关于python3.4.3下逐行读入txt文本并去重的方法,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下读写文件时应注意的问题包括:
1.字符编码
2.操作完成即时关闭文件描述符
3.代码兼容性
几种方法:
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 60 61 62 63 |
|
结果:
去重前:
去重后(无序):
去重后(有序):
总结
这段下程序涉及文件读写操作以及链表List的操作,文章开头提到的几个问题,由于并没有使用中文,所以不关心编码,但这里还是要提一提:
1 2 |
|
上面这段代码如果在python2中运行会报错
报错是因为程序没办法直接保存unicode字符串,要经过编码转换成str类型的二进制字节序列才可以保存。
write()方法会自动编码转换,默认使用ascii编码格式,而ascii不能处理中文,所以出现UnicodeEncodeError。
正确方式是在调用write()方法前,手动格式转换,用utf-8或者gbk转换成str。
1 2 3 4 |
|
关于close()问题:
不关闭会有什么影响呢?操作完成后,不关闭文件,会对系统资源造成浪费,因为系统可打开的文件描述符数量是有限的。Linux是65535。
一般来说close之后就OK了,但是也会存在特殊情况,比如说,在调用open()函数时就已经发生错误,权限不足,调用close()肯定报错。还有一种是在write()时,如果磁盘空间不足,报错,close()就没有机会执行了。正确的做法就是使用 try except 对异常进行捕获:
1 2 3 4 5 6 7 8 9 |
|
更优雅的写法是用 with…as。
1 2 3 |
|
文件对象实现上下午管理器协议,程序进入with语句时,会把文件对象赋值给变量f,在程序退出with时会自动的调用close()方法。
关于兼容性问题:
python2和python3的open()函数是不一样的,后者可以在函数中指定字符编码格式。
如何解决python2和python3的兼容open()问题呢?
使用io模块下的open()函数,python2中的io.open等价与python3的open函数
1 2 3 |
|
相关推荐:
python下解压缩zip文件并删除文件的实例_python
以上就是python3.4.3下逐行读入txt文本并去重的方法的详细内容,更多文章请关注木庄网络博客!!
相关阅读 >>
更多相关阅读请进入《Python》频道 >>

Python编程 从入门到实践 第2版
python入门书籍,非常畅销,超高好评,python官方公认好书。