python 查询文本文件的层次
生活随笔
收集整理的這篇文章主要介紹了
python 查询文本文件的层次
小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
I/O系統(tǒng)有一系列的層次構(gòu)建而成
下面是操作一個(gè)文本文件的例子來(lái)查看這種層次
>>> f = open('sample.txt','w') >>> f <_io.TextIOWrapper name='sample.txt' mode='w' encoding='UTF-8'> >>> f.buffer <_io.BufferedWriter name='sample.txt'> >>> f.buffer.raw <_io.FileIO name='sample.txt' mode='wb'> >>>io.TextIOWrapper 是一個(gè)編碼和解碼Unicode 的文本處理層,io.BufferedWriter 是一個(gè)處理二進(jìn)制數(shù)據(jù)的帶緩沖的I/O 層,io.FileIO 是一個(gè)表示操作系統(tǒng)底層文件描述符的原始文件,增加或改變文本編碼會(huì)涉及增加或改變最上面的io.TextIOWrapper 層
一般來(lái)講,像上面例子這樣通過(guò)訪(fǎng)問(wèn)屬性值來(lái)直接操作不同的層是很不安全的,如果你試著使用下面這樣的技術(shù)改變編碼看看會(huì)發(fā)生什么
''' 遇到問(wèn)題沒(méi)人解答?小編創(chuàng)建了一個(gè)Python學(xué)習(xí)交流QQ群:857662006 尋找有志同道合的小伙伴,互幫互助,群里還有不錯(cuò)的視頻學(xué)習(xí)教程和PDF電子書(shū)! ''' >>> f <_io.TextIOWrapper name='sample.txt' mode='w' encoding='UTF-8'> >>> f = io.TextIOWrapper(f.buffer, encoding='latin-1') >>> f <_io.TextIOWrapper name='sample.txt' encoding='latin-1'> >>> f.write('Hello') Traceback (most recent call last): File "<stdin>", line 1, in <module> ValueError: I/O operation on closed file. >>>結(jié)果出錯(cuò)了,因?yàn)閒 的原始值已經(jīng)被破壞了并關(guān)閉了底層的文件,
detach() 方法會(huì)斷開(kāi)文件的最頂層并返回第二層,之后最頂層就沒(méi)什么用了
>>> f = open('sample.txt', 'w') >>> f <_io.TextIOWrapper name='sample.txt' mode='w' encoding='UTF-8'> >>> b = f.detach() >>> b <_io.BufferedWriter name='sample.txt'> >>> f.write('hello') Traceback (most recent call last): File "<stdin>", line 1, in <module> ValueError:underlying buffer has been detached一旦斷開(kāi)最頂層后,你就可以給返回結(jié)果添加一個(gè)新的最頂層
>>> f = io.TextIOWrapper(b, encoding='latin-1') >>> f <_io.TextIOWrapper name='sample.txt' encoding='latin-1'> >>>總結(jié)
以上是生活随笔為你收集整理的python 查询文本文件的层次的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: python 将文件描述符包装成文件对象
- 下一篇: Python3.8 新特性:赋值表达式