Python財(cái)經(jīng)應(yīng)用-編程基礎(chǔ)、數(shù)據(jù)分析與可視化課件 第3章-Python文件操作-3.4CSV文件讀取與寫入操作_第1頁(yè)
Python財(cái)經(jīng)應(yīng)用-編程基礎(chǔ)、數(shù)據(jù)分析與可視化課件 第3章-Python文件操作-3.4CSV文件讀取與寫入操作_第2頁(yè)
Python財(cái)經(jīng)應(yīng)用-編程基礎(chǔ)、數(shù)據(jù)分析與可視化課件 第3章-Python文件操作-3.4CSV文件讀取與寫入操作_第3頁(yè)
Python財(cái)經(jīng)應(yīng)用-編程基礎(chǔ)、數(shù)據(jù)分析與可視化課件 第3章-Python文件操作-3.4CSV文件讀取與寫入操作_第4頁(yè)
Python財(cái)經(jīng)應(yīng)用-編程基礎(chǔ)、數(shù)據(jù)分析與可視化課件 第3章-Python文件操作-3.4CSV文件讀取與寫入操作_第5頁(yè)
已閱讀5頁(yè),還剩10頁(yè)未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

Python財(cái)經(jīng)應(yīng)用:編程基礎(chǔ)、數(shù)據(jù)分析與可視化第三章Python文件操作中國(guó)農(nóng)業(yè)大學(xué)李輝01

文件相關(guān)的基本概念02

文件夾與目錄操作03

文件的基本操作04

CSV文件讀取與寫入操作01

文件相關(guān)的基本概念02

文件夾與目錄操作03

文件的基本操作04

CSV文件讀取與寫入操作3.4CSV文件讀取與寫入操作第三章Python文件操作CSV文件

讀取與寫入操作CSV文件,全稱為字符分隔值(CommaSeparatedValues,CSV)文件,其分隔符并非僅限于逗號(hào),制表符同樣可作為分隔依據(jù)。CSV作為一種常見的文本格式,在存儲(chǔ)表格數(shù)據(jù)方面應(yīng)用廣泛,其中涵蓋了數(shù)字以及各類字符信息。CSV文件具備以下顯著特點(diǎn):屬于純文本形式,可采用諸如ASCII、Unicode或GB-2312等特定字符集。數(shù)據(jù)讀取以行為基本單位,每行代表一條記錄。每條記錄借助分隔符劃分成不同字段。每條記錄均遵循相同的字段序列排列。CSV文件讀取與寫入操作——讀取CSV文件writer(fileobj)方法:根據(jù)文件對(duì)象fileobj創(chuàng)建并返回一個(gè)用于寫操作的CSV文件對(duì)象。調(diào)用該CSV文件對(duì)象的writerow()方法或writerows()方法可以將一行或多行數(shù)據(jù)寫入CSV文件。reader(iterable)方法:根據(jù)可迭代對(duì)象iterable(如文件對(duì)象或列表)創(chuàng)建并返回一個(gè)用于讀操作的CSV文件對(duì)象。該CSV文件對(duì)象每次可以迭代CSV文件中的一行,并將該行中的各列數(shù)據(jù)以字符串的形式存入列表后再返回該列表。【例3-18】利用reader()方法讀取studentinfo.csv文件,并顯示文件內(nèi)容。CSV文件讀取與寫入操作——讀取CSV文件實(shí)現(xiàn)代碼如下:

importcsvwithopen(".\\data\\居民消費(fèi)價(jià)格指數(shù).csv",'r')asf:csv_reader=csv.reader(f)rows=[rowforrowincsv_reader]foriteminrows:print(item)f.close()CSV文件讀取與寫入操作——讀取CSV文件運(yùn)行結(jié)果如下:

['數(shù)據(jù)庫(kù):分省月度數(shù)據(jù)']['指標(biāo):居民消費(fèi)價(jià)格指數(shù)(上年同月=100)']['時(shí)間:最近13個(gè)月']……csv_reader是一個(gè)可迭代對(duì)象,它每次迭代CSV文件中的一行,并將該行中的各列數(shù)據(jù)以字符串的形式存入列表后再返回該列表。CSV文件讀取與寫入操作——CSV文件寫入與關(guān)閉文件的寫入:write(方法的主要功能在于向文件寫入特定的字符串。在此過(guò)程中,需將open函數(shù)里文件打開的參數(shù)設(shè)定為mode='w'。write方法函數(shù)采用逐次寫入的方式,而writelines()方法則能夠一次性將一個(gè)列表內(nèi)的所有數(shù)據(jù)寫入文件。若存在換行需求,那么應(yīng)當(dāng)在每條數(shù)據(jù)的末尾添加換行符。并且,可以運(yùn)用“字符串.join()”的方法把各個(gè)變量數(shù)據(jù)連接成一個(gè)字符串,同時(shí)添加間隔符“\t”。另外,針對(duì)寫入CSV文件的writer()方法而言,能夠調(diào)用writerow()方法把列表中的每個(gè)元素按行寫入文件,從而實(shí)現(xiàn)數(shù)據(jù)的有效寫入與整理?!纠?-19】合并分省月度居民消費(fèi)價(jià)格數(shù)據(jù)集。經(jīng)分析,每個(gè)數(shù)據(jù)文件具有相似的結(jié)構(gòu),前三行為數(shù)據(jù)的基本信息描述,中間多行為具體的區(qū)域省份月度數(shù)據(jù),每個(gè)數(shù)據(jù)文件的省份行數(shù)并不相同,最后四行為數(shù)據(jù)文件的說(shuō)明,該說(shuō)明以“注’開頭。CSV文件讀取與寫入操作——CSV文件寫入與關(guān)閉實(shí)現(xiàn)代碼如下:

fw_combine_data=open('combine_data.csv','w',encoding='UTF-8')foriinrange(1,6):fr_data=open(f'.\\data\\居民消費(fèi)價(jià)格分省月度數(shù)據(jù){i}.csv')ifi==1:foriinrange(3): #注意觀察每個(gè)數(shù)據(jù)文件的行數(shù)fr_data.readline()else:forjinrange(4):fr_data.readline()CSV文件讀取與寫入操作——CSV文件寫入與關(guān)閉

whileTrue:record=fr_data.readline()ifrecord[0]=='注':breakelse:fw_combine_data.write(record)fr_data.close()fw_combine_data.close()print('合并數(shù)據(jù)集成功!')CSV文件讀取與寫入操作——CSV文件寫入與關(guān)閉運(yùn)行結(jié)果如下:

合并數(shù)據(jù)集成功!open函數(shù)中的newline參數(shù)用于管理通用換行符的處理方式,其可接收的值包括None、''、'\n'、'\r'以及'\r\n'。其工作機(jī)理如下所述:在從流中讀取數(shù)據(jù)時(shí),若newline參數(shù)設(shè)為None,則啟用通用換行符模式,流中的換行符可以是'\n'、'\r'或'\r\n',這些換行符在讀取時(shí)均會(huì)被統(tǒng)一轉(zhuǎn)換為'\n'。若newline參數(shù)為'',則同樣啟用換行符模式,但行尾的換行符在返回行內(nèi)容時(shí)不會(huì)被轉(zhuǎn)換。若指定了其他有效的參數(shù)值,則在返回行內(nèi)容時(shí),換行符將按照指定的參數(shù)值進(jìn)行處理。當(dāng)向流中寫入數(shù)據(jù)時(shí),若newline參數(shù)為None,則寫入流中的任何'\n'字符都將被轉(zhuǎn)換為系統(tǒng)默認(rèn)的換行符。若newline參數(shù)為''或'\n',則寫入的'\n'字符將保持不變,不會(huì)進(jìn)行轉(zhuǎn)換。若指定了其他有效的參數(shù)值,寫入流中的'\n'字符將被轉(zhuǎn)換為指定的換行符序列。文件的基本操作——文件的打開和關(guān)閉文件的打開與新建:open()方法的應(yīng)用場(chǎng)景有如下三種情況:(3)打開文件時(shí)指定編碼方式在使用open函數(shù)打開文件時(shí),默認(rèn)采用GBK編碼,當(dāng)被打開的文件不是GBK編碼時(shí),也將拋出異常。一般可以通過(guò)直接修改文件的編碼,或者在打開文件時(shí),直接指定使用的編碼方式。推薦采用后一種方法。比如:打開采用UTF-8編碼保存的data.txt文件,可以使用下面的代碼:

f=open('data.txt','r',encoding='utf-8')本章主要介紹了Python編程基礎(chǔ),主要包括Python的基本語(yǔ)法、內(nèi)置數(shù)據(jù)類型、函數(shù)以及文件操作。文件是數(shù)據(jù)的抽象和集合,文件方式可以持久地保存數(shù)據(jù)。Python通過(guò)調(diào)用標(biāo)準(zhǔn)庫(kù)和豐富的第三方庫(kù)提供的方法對(duì)多種格式的文件進(jìn)行管理和操作。Python程序?qū)τ?jì)算機(jī)本地文件進(jìn)行操作的一般步驟:打開文件并創(chuàng)建文件對(duì)象;通過(guò)文件對(duì)象進(jìn)行文件內(nèi)容的讀取、寫入、刪除、修改等操作;關(guān)閉文件并保存文件的內(nèi)容。對(duì)于文件訪問(wèn)操作,推薦使用上下文管理語(yǔ)句with,不論因?yàn)槭裁丛蚨鰓it

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論