欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python?open函數(shù)中newline參數(shù)實例詳解

 更新時間:2022年06月22日 10:52:26   作者:我是個燒餅啊  
newLine()方法可用于輸出一個換行字符"/n",下面這篇文章主要給大家介紹了關(guān)于python?open函數(shù)中newline參數(shù)的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下

問題的由來

我在讀pythoncsv模塊文檔 看到了這樣一句話

如果 csvfile 是文件對象,則打開它時應(yīng)使用 newline=‘’。
其備注:如果沒有指定 newline=‘’,則嵌入引號中的換行符將無法正確解析,并且在寫入時,使用 \r\n 換行的平臺會有多余的 \r 寫入。由于 csv 模塊會執(zhí)行自己的(通用)換行符處理,因此指定 newline=‘’ 應(yīng)該總是安全的。

我就在思考open函數(shù)中的newline參數(shù)的作用,因為自己之前在使用open函數(shù)時從來沒有設(shè)置過newline參數(shù),僅從上面官方給的備注理解newline參數(shù)可以幫助處理換行符解析的問題

并且查閱得知不同操作系統(tǒng)換行符并不一致:

Unix 的行結(jié)束約定 ‘\n’、Windows 的約定 ‘\r\n’ 以及舊版 Macintosh 的約定 ‘\r’

打破了我原本觀念以為的換行符就是\n

python官方文檔對newline參數(shù)解釋:

newline 控制 universal newlines 模式如何生效(它僅適用于文本模式)。它可以是 None,‘’,‘\n’,‘\r’ 和 ‘\r\n’。它的工作原理:
從流中讀取輸入時,如果 newline 為 None,則啟用通用換行模式。輸入中的行可以以 ‘\n’,‘\r’ 或 ‘\r\n’ 結(jié)尾,這些行被翻譯成 ‘\n’ 在返回呼叫者之前。如果它是 ‘’,則啟用通用換行模式,但行結(jié)尾將返回給調(diào)用者未翻譯。如果它具有任何其他合法值,則輸入行僅由給定字符串終止,并且行結(jié)尾將返回給未調(diào)用的調(diào)用者。
將輸出寫入流時,如果 newline 為 None,則寫入的任何 ‘\n’ 字符都將轉(zhuǎn)換為系統(tǒng)默認行分隔符 os.linesep。如果 newline 是 ‘’ 或 ‘\n’,則不進行翻譯。如果 newline 是任何其他合法值,則寫入的任何 ‘\n’ 字符將被轉(zhuǎn)換為給定的字符串。

從這也就理解了為什么原本使用open()寫的時候用\n就可以表示換行以及讀文本文件時行尾會返回\n

  • 寫入的時候沒有指定newline參數(shù)會將\n翻譯成系統(tǒng)默認的行分割符(\r\n)
  • 讀的時候沒有指定newline參數(shù)會將行分割符(\r\n)翻譯為\n

回到上文,那為什么在讀寫csv文件時就要設(shè)置newline=''呢?

pythoncsv官方文檔解釋了這一問題(這也就引入了第二種方法解決換行的問題,我在后面會介紹到)

Dialect.lineterminator
放在 writer 產(chǎn)生的行的結(jié)尾,默認為 ‘\r\n’。
注解 reader 經(jīng)過硬編碼,會識別 ‘\r’ 或 ‘\n’ 作為行尾,并忽略 lineterminator。未來可能會更改這一行為。

用白話說就是writerow()方法在寫入一行數(shù)據(jù)時在行尾都會跟一個默認換行符(\r\n)(即csv是將’一行數(shù)據(jù)\r\n’寫入內(nèi)存,此時這一行數(shù)據(jù)還在內(nèi)存中,還沒有寫入文件)之后執(zhí)行代碼真正在向文件寫入時根據(jù)不同newline參數(shù)進行翻譯
而在向txt文件使用write()方法寫入內(nèi)容時是我們手動添加換行符\n(內(nèi)存中的數(shù)據(jù)就是我們寫入的內(nèi)容,并不會隱式添加其他內(nèi)容)之后執(zhí)行代碼真正在向文件寫入時根據(jù)newline參數(shù)進行翻譯,這就是二者的區(qū)別
具體流程:
newline=‘’
writer.writerow(‘line’) 實際是向內(nèi)存中寫入’line\r\n’ --》 執(zhí)行代碼,寫入文件,根據(jù)newline=‘’,將不進行翻譯 --》文件最終寫入’line\r\n’
newline=None(默認)
f.write(‘line\n’) 直接將’line\n’寫入內(nèi)存 --》 執(zhí)行代碼,寫入文件,根據(jù)newline=None,將\n翻譯為\r\n --》文件最終寫入’line\r\n’

具體實例

case1: w newline=‘’ r newline=‘’

import csv
with open("test.csv","w",encoding='utf-8',newline='') as csvfile:
	    writer=csv.writer(csvfile)
	    writer.writerow(["num","name","grade"])
	    writer.writerows([[1,'luke','96'],[2,'jack','85'],[3,'nick','84']])
with open("test.csv","r",encoding='utf-8',newline='') as csvfile:
	    txtdata=csvfile.read()
txtdata      #>>'num,name,grade\r\n1,luke,96\r\n2,jack,85\r\n3,nick,84\r\n'

case2: w newline=‘\r’ r newline=‘’

import csv
with open("test.csv","w",encoding='utf-8',newline='\r') as csvfile:
	    writer=csv.writer(csvfile)
	    writer.writerow(["num","name","grade"])
	    writer.writerows([[1,'luke','96'],[2,'jack','85'],[3,'nick','84']])
with open("test.csv","r",encoding='utf-8',newline='') as csvfile:
	    txtdata=csvfile.read()
txtdata  #>>'num,name,grade\r\r1,luke,96\r\r2,jack,85\r\r3,nick,84\r\r'

case3: w newline=‘\r\n’ r newline=‘’

import csv
with open("test.csv","w",encoding='utf-8',newline='\r\n') as csvfile:
	    writer=csv.writer(csvfile)
	    writer.writerow(["num","name","grade"])
	    writer.writerows([[1,'luke','96'],[2,'jack','85'],[3,'nick','84']])
with open("test.csv","r",encoding='utf-8',newline='') as csvfile:
	    txtdata=csvfile.read()
txtdata  #>>'num,name,grade\r\r\n1,luke,96\r\r\n2,jack,85\r\r\n3,nick,84\r\r\n'

case4: w newline=None r newline=None

import csv
with open("test.csv","w",encoding='utf-8',newline=None) as csvfile:
	    writer=csv.writer(csvfile)
	    writer.writerow(["num","name","grade"])
	    writer.writerows([[1,'luke','96'],[2,'jack','85'],[3,'nick','84']])
with open("test.csv","r",encoding='utf-8',newline=None) as csvfile:
	    txtdata=csvfile.read()
txtdata  #>>'num,name,grade\n\n1,luke,96\n\n2,jack,85\n\n3,nick,84\n\n'

case5: 文件寫入為\r\r\n 文件讀取 newline=‘\r’

with open("test.csv","r",encoding='utf-8',newline='') as csvfile:
	txtdata=csvfile.read()
txtdata  #>>'num,name,grade\r\r\n1,luke,96\r\r\n2,jack,85\r\r\n3,nick,84\r\r\n'
import csv
with open("test.csv","r",encoding='utf-8',newline='\r') as csvfile:
    content = csv.reader(csvfile)
    for i in content:
        print(i)

為什么會報錯:

csv.reader是如何讀取\r\r\n的:讀取時遇到\r認為一行結(jié)束了,再一次遇到\r同樣認為一行結(jié)束(因而返回了空串列表),遇到\n無法解釋–》報錯

case6:文件寫入為\r\r\n 文件讀取 newline=‘\n’

with open("test.csv","r",encoding='utf-8',newline='') as csvfile:
    txtdata=csvfile.read()
txtdata  #>>'num,name,grade\r\r\n1,luke,96\r\r\n2,jack,85\r\r\n3,nick,84\r\r\n'
import csv
with open("test.csv","r",encoding='utf-8',newline='\n') as csvfile:
    content = csv.reader(csvfile)
    for i in content:
        print(i)

case7:文件寫入為\r\r\n 文件讀取newline=‘\r\n’

with open("test.csv","r",encoding='utf-8',newline='') as csvfile:
    txtdata=csvfile.read()
txtdata  #>>'num,name,grade\r\r\n1,luke,96\r\r\n2,jack,85\r\r\n3,nick,84\r\r\n'
import csv
with open("test.csv","r",encoding='utf-8',newline='\r\n') as csvfile:
    content = csv.reader(csvfile)
    for i in content:
        print(i)

case8:文件寫入為\r\r 文件讀取 newline=‘\r’

with open("test.csv","r",encoding='utf-8',newline='') as csvfile:
    txtdata=csvfile.read()
txtdata  #>>'num,name,grade\r\r1,luke,96\r\r2,jack,85\r\r3,nick,84\r\r'
import csv
with open("test.csv","r",encoding='utf-8',newline='\r') as csvfile:
    content = csv.reader(csvfile)
    for i in content:
        print(i)

第二種方法:通過設(shè)置csv.writer方法中的lineterminator參數(shù)

上面提到lineterminator參數(shù)控制writer寫入每一行后跟的隱式結(jié)束符,默認為’\r\n’,因此我們需要要設(shè)置lineterminator=‘\n’,讀取時也不需要設(shè)置newline參數(shù)即可獲得想要的效果

import csv
with open("test.csv","w",encoding='utf-8') as csvfile:
    writer=csv.writer(csvfile,lineterminator='\n')
    writer.writerow(["num","name","grade"])
    writer.writerows([[1,'luke','96'],[2,'jack','85'],[3,'nick','84']])
with open("test.csv","r",encoding='utf-8') as csvfile:
    lst=csv.reader(csvfile)
    csvfile.seek(0)
    txtdata = csvfile.read()
    csvfile.seek(0)
    for i in lst:
        print(i)
txtdata #>>'num,name,grade\n1,luke,96\n2,jack,85\n3,nick,84\n'

總結(jié)

到此這篇關(guān)于python open函數(shù)中newline參數(shù)實例詳解的文章就介紹到這了,更多相關(guān)python open函數(shù)newline參數(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 詳細講解用Python發(fā)送SMTP郵件的教程

    詳細講解用Python發(fā)送SMTP郵件的教程

    這篇文章主要詳細講解了用Python發(fā)送SMTP郵件的教程,包括在郵件中添加圖片等文件,強烈推薦!需要的朋友可以參考下
    2015-04-04
  • 用Python徒手擼一個股票回測框架搭建【推薦】

    用Python徒手擼一個股票回測框架搭建【推薦】

    回測框架就是提供這樣的一個平臺讓交易策略在歷史數(shù)據(jù)中不斷交易,最終生成最終結(jié)果,通過查看結(jié)果的策略收益,年化收益,最大回測等用以評估交易策略的可行性。這篇文章主要介紹了用Python徒手擼一個股票回測框架,需要的朋友可以參考下
    2019-08-08
  • Python3中map(),reduce(),filter()的詳細用法

    Python3中map(),reduce(),filter()的詳細用法

    這篇文章主要介紹了Python3中map(),reduce(),filter()的詳細用法,Python3中的map()、reduce()、filter()?這3個一般是用于對序列進行操作的內(nèi)置函數(shù),它們經(jīng)常需要與?匿名函數(shù)?lambda?聯(lián)合起來使用
    2022-08-08
  • wxpython自定義下拉列表框過程圖解

    wxpython自定義下拉列表框過程圖解

    這篇文章主要介紹了wxpython自定義下拉列表框過程圖解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-02-02
  • Python演化計算基準函數(shù)詳解

    Python演化計算基準函數(shù)詳解

    這篇文章主要介紹了Python演化計算基準函數(shù),非常不錯,具有一定的參考借鑒價值,需要的朋友參考下吧,希望能夠給你帶來幫助
    2021-10-10
  • Python Lambda函數(shù)使用總結(jié)詳解

    Python Lambda函數(shù)使用總結(jié)詳解

    這篇文章主要介紹了Python Lambda函數(shù)使用總結(jié)詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-12-12
  • python實現(xiàn)簡易猜數(shù)小游戲

    python實現(xiàn)簡易猜數(shù)小游戲

    大家好,本篇文章主要講的是python實現(xiàn)簡易猜數(shù)小游戲,感興趣的同學趕快來看一看吧,對你有幫助的話記得收藏一下,方便下次瀏覽
    2022-01-01
  • python兩種遍歷字典(dict)的方法比較

    python兩種遍歷字典(dict)的方法比較

    這篇文章主要介紹了python兩種遍歷字典(dict)的方法比較,同時介紹了dict遍歷中帶括號與不帶括號的性能問題,需要的朋友可以參考下
    2014-05-05
  • Python進階之如何快速將變量插入有序數(shù)組

    Python進階之如何快速將變量插入有序數(shù)組

    在我們學習python的過程中,學習序列是一門必修課。本文我們就來一起看一看Python是如何快速將變量插入有序數(shù)組的,感興趣的可以了解一下
    2023-04-04
  • Python性能提升之延遲初始化

    Python性能提升之延遲初始化

    本文給大家分享的是在Python中使用延遲計算來提升性能的方法,非常的實用,有需要的小伙伴可以參考下
    2016-12-12

最新評論