讀取整個(gè)文件
讀取文件先要?jiǎng)?chuàng)建一個(gè)文件,在程序的同一目錄下。
greet.txt
“Hello World!
Hello World!
Hello World!
Hello World!”
with open('greet.txt') as file_object: contents=file_object.read() print(contents)
如果txt文件中有中文,輸出出現(xiàn)亂碼時(shí),可以with open(‘greet.txt',encoding=‘UTF-8') as file_object:。
要以任何方式使用文件時(shí),都必須先打開文件,才能訪問。函數(shù)open()接受一個(gè)參數(shù),打開文件的名稱。在這里open(‘greet.txt')返回的是一個(gè)表示文件greet.txt的對(duì)象,然后將該對(duì)象賦給file_object供以后使用。
關(guān)鍵字with在不再需要訪問文件后將其關(guān)閉。也可以調(diào)用open()和close()來打開文件。但是不推薦。
方法read()讀取文件的全部內(nèi)容,并將其作為一個(gè)長長的字符串賦給變量contents。
with open('greet.txt',encoding='UTF-8') as file_object: for line in file_object: print(line)
會(huì)發(fā)現(xiàn)多輸出空白行,文件末尾會(huì)有一個(gè)換行符,而print會(huì)換行,所以就多了,可以使用rstrip()。
with open('greet.txt',encoding='UTF-8') as file_object: for line in file_object: print(line.rstrip())
with open('greet.txt',encoding='UTF-8') as file_object: lines=file_object.readlines() for line in lines: print(line.rstrip())
readlines()從文件讀取每一行,并將其存在一個(gè)列表中。
greet_str='' with open('greet.txt',encoding='UTF-8') as file_object: lines=file_object.readlines() for line in lines: greet_str+=line input_str=input('輸入你想查找的字符串') if input_str in greet_str: print('有') else : print('無')
message='Hello World!' print(message.replace('World','China'))
with open('greet.txt','w',encoding='UTF-8') as file_object: file_object.write('我愛編程')
w'告訴Python要以寫入模式打開這個(gè)文件。打開文件時(shí)可以指定模式:讀取模式'r‘,寫入模式'w',附加模式‘a(chǎn)'或讀寫模式'r+‘。如果省略了模式實(shí)參,則默認(rèn)只讀模式打開文件。
使用寫入模式時(shí)要小心,因?yàn)闀?huì)把文件的內(nèi)容清空。
函數(shù)write()不會(huì)在文本末尾加換行符所以要我們自己添加。
如果要在文件末尾附加內(nèi)容,可以打開附加模式,如果指定文件不存在,Python將自動(dòng)創(chuàng)建一個(gè)空文件。
先greet.txt
with open('greet.txt','a',encoding='UTF-8') as file_object: file_object.write('我愛編程\n')
后greet.txt
Python使用稱為異常的特殊對(duì)象來管理程序執(zhí)行期間發(fā)生的錯(cuò)誤。
異常是使用try-except代碼塊進(jìn)行處理的。
try: print(4/0) except ZeroDivisionError: print('不能數(shù)以0')
如果代碼塊try-except后面還有代碼將接著運(yùn)行。
try: print(4/0) except ZeroDivisionError: print('不能數(shù)以0') print('--==')
使用文件時(shí)如果找不到文件,可以使用try-except代碼塊。
分析文本 split()
split()能根據(jù)一個(gè)字符串創(chuàng)建一個(gè)列表,它以空格為分隔符將字符串拆成多個(gè)部分。
str='你好 世界' print(str.split())
當(dāng)發(fā)生異常時(shí)我們也可以什么都不做。
try: print(4/0) except ZeroDivisionError: pass
pass也可以提示我們什么都沒有做。
模塊json可以將簡單的數(shù)據(jù)結(jié)構(gòu)儲(chǔ)存在文件當(dāng)中。json
不僅僅能在python中分享數(shù)據(jù),也可以給其他編程語言分享。
import json number=list(range(10)) with open('number.json','w') as file: json.dump(number,file)
json.dump()接受兩個(gè)實(shí)參:要 儲(chǔ)存的數(shù)據(jù)和儲(chǔ)存數(shù)據(jù)的文件對(duì)象。文件通常使用文件擴(kuò)展名.json來支出文件儲(chǔ)存的數(shù)據(jù)為JSON格式。
import json with open('number.json') as file: number=json.load(file) print(number)
將代碼改進(jìn)的過程稱為重構(gòu)。重構(gòu)使代碼更加清晰,更易于理解,更容易擴(kuò)容。
到此這篇關(guān)于python基礎(chǔ)之文件和異常處理的文章就介紹到這了,更多相關(guān)python文件和異常內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
標(biāo)簽:金華 貴州 克拉瑪依 陽泉 日照 臨汾 赤峰 雙鴨山
巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《python基礎(chǔ)之文件操作和異常處理》,本文關(guān)鍵詞 python,基礎(chǔ),之,文件,操作,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。