python異常和文件處理機(jī)制詳解
本文實(shí)例講述了python異常和文件處理機(jī)制。分享給大家供大家參考,具體如下:
1 異常處理
Python的異常用
try
except
finally
來(lái)處理. 并且except后還可以跟 else .
引發(fā)異常用 raise
如果拋出的異常沒(méi)有被處理. 在Python IDE中是顯示一些紅色的信息. 在真正的Python程序運(yùn)行時(shí). 會(huì)導(dǎo)致程序終止.
在以前我們已經(jīng)見(jiàn)到過(guò)一下幾種異常:
在 Dictionary 中如果使用的 key 不存在. 會(huì)引發(fā) KeyError 異常. 如:
>>> d = {"a":1, "b":"abc"} >>> d["c"] Traceback (most recent call last): File "<interactive input>", line 1, in <module> KeyError: 'c'
搜索列表中不存在的值. 將引發(fā) ValueError 異常. 如:
>>> li = [1,2] >>> li.index(3) Traceback (most recent call last): File "<interactive input>", line 1, in <module> ValueError: list.index(x): x not in list
對(duì)應(yīng)的. 若用下標(biāo)來(lái)引用列表中的元素. 若下標(biāo)出界. 會(huì)產(chǎn)生 IndexError 異常. 如:
>>> li[2] Traceback (most recent call last): File "<interactive input>", line 1, in <module> IndexError: list index out of range
調(diào)用不存在的方法. 會(huì)引發(fā) AttributeError 異常.
引用不存在的變量. 引發(fā) NameError 異常.
未強(qiáng)制轉(zhuǎn)化就混用數(shù)據(jù)類(lèi)型. 引發(fā) TypeError 異常.
文件操作錯(cuò)誤引發(fā)的 IOError. 如:
try: fsock = open("/notthere") except IOError: print "The file dose not exits..." else: print "open the file." print "this line will always print"
注意上邊的代碼中:
open 是一個(gè)內(nèi)置函數(shù). 用來(lái)打開(kāi)文件. 并返回一個(gè)文件對(duì)象.
try except 后邊可以跟 else 語(yǔ)句. 當(dāng)沒(méi)有捕捉到指定的異常時(shí). 執(zhí)行else 語(yǔ)句.
導(dǎo)入一個(gè)模塊時(shí). 若模塊不存在. 會(huì)引發(fā) ImportError 異常.
還可以定義自己的異常類(lèi). 定義時(shí)讓它繼承內(nèi)置的 Exception 類(lèi). 然后在需要拋出異常時(shí)用 raise 拋出.
2 與文件對(duì)象共事
前面說(shuō)過(guò)用 open 可以打開(kāi)文件并返回文件對(duì)象. 它的函數(shù)聲明如下:
open(name[, mode[, buffering]])
有3個(gè)參數(shù)(其中后兩個(gè)是可選的). 分別表示 文件名. 打開(kāi)方式. 緩沖區(qū)參數(shù). 例如:
>>> f = open("/music/_singles/kairo.mp3", "rb")
第2個(gè)參數(shù)指定為"rb". 表示以2進(jìn)制讀打開(kāi)文件. 如果這個(gè)參數(shù)缺省. 則表示以文本方式打開(kāi).
如果不能打開(kāi). 則open引發(fā) IOError 異常.
現(xiàn)在可以用文件對(duì)象的 name 屬性和 mode 屬性來(lái)查詢(xún)它們. 如:
>>> f.name '/music/_singles/kairo.mp3' >>> f.mode 'rb'
打開(kāi)文件后. 就可以進(jìn)行讀寫(xiě)了. 如:
>>> f.tell()
查詢(xún)當(dāng)前位置.
0 >>> f.seek(0, 2)
定位文件指針. 第一個(gè)參數(shù)是偏移值. 第二個(gè)可以取0. 1. 2三個(gè)值. 分別表示開(kāi)頭. 當(dāng)前位置. 末尾.
若定位的地址不正確(例如超過(guò)范圍) 則引發(fā)IOError異常.
所以這個(gè)語(yǔ)句就把文件指針定位到了文件尾.
>>> f.tell()
這將打印文件的長(zhǎng)度.
>>> f.seek(-128, 2) >>> data = f.read(128)
讀取文件的最后128字節(jié). 并將讀入的的數(shù)據(jù)作為字符串返回. 讀取數(shù)據(jù)時(shí)也同時(shí)后移文件指針.
其中 read 的參數(shù)表示最大讀取字節(jié)數(shù). 也可以省略這個(gè)參數(shù). 則表示一直讀到文件末尾.
若讀取時(shí)出現(xiàn)錯(cuò)誤(如磁盤(pán)上有壞扇區(qū)或網(wǎng)絡(luò)已斷開(kāi)). 引發(fā)IOError 異常.
>>> f.closed
查看文件是否關(guān)閉.
False >>> f.close()
不再使用時(shí)應(yīng)該關(guān)閉文件. 可以對(duì)一個(gè)已經(jīng)關(guān)閉的文件再次關(guān)閉(不會(huì)發(fā)生異常).
>>> f.closed True
關(guān)閉之后如果再對(duì) f 進(jìn)行 seek() 等操作. 會(huì)引發(fā) ValueError 異常.
寫(xiě)入文件的辦法和讀取類(lèi)似. 不過(guò)它要求文件是 "寫(xiě)" 打開(kāi)的. 如:
>>> f1 = open('test.log', 'w')
其中 'w' 表示寫(xiě)打開(kāi). 這樣即使文件不存在. 也會(huì)創(chuàng)建. 如果存在. 則覆蓋現(xiàn)有的文件.
>>> f1.write('abc') >>> f1.close() >>> file('test.log').read()
用 file()打開(kāi)文件和用open()打開(kāi)是一樣的. 所以打印:
'abc'
3 for循環(huán)
在Python中. for用來(lái)在一個(gè)List上遍歷. 如:
>>> li = [1, 2, 3] >>> for i in li:
這會(huì)在循環(huán)中讓 i 依次接收 li 中的元素的值.
... print i
...
1
2
3
這個(gè)輸出和 print "\n".joni(li) 一樣.
如果要象其它語(yǔ)言中一樣. 讓for做計(jì)數(shù)使用. 可以用如下的辦法:
>>> for i in range(len(li)) : print li[i] ... 1 2 3
要用 for 來(lái)遍歷 Dictionary . 如下:
>>> d = {1:"abc", 2:"def"} >>> for k, v in d.items() : print "%d = %s" % (k, v) ... 1 = abc 2 = def
上邊的打印結(jié)果和 print "\n".join(["%d = %s" % (k, v) for k, v in d.items()]) 一樣.
4 使用 sys.modules
在Python中. modules 是定義在sys模塊中的一個(gè)全局的字典對(duì)象.
一旦我們import一個(gè)模塊. 就可以在 sys.modules 中找到它.
每個(gè)類(lèi)都擁有一個(gè)內(nèi)置的"類(lèi)屬性" : __module__ . 其值為定義該類(lèi)的模塊的名字.
5 與Directory共事
在os.path 所引用的模塊中有幾個(gè)操作文件和目錄的函數(shù).如:
>>> import os >>> os.path.join("c:\music", "mahadeva.mp3")
這個(gè)join函數(shù)用來(lái)將一個(gè)或多個(gè)字符串構(gòu)造成一個(gè)路徑名.
'c:\music\mahadeva.mp3' >>> os.path.expanduser("~")
expanduser函數(shù)用'~'作參數(shù)時(shí). 返回當(dāng)前用戶(hù)根目錄.
'c:\Documents and Settings\mpilgrim\My Documents'
>>> (filepath, filename) = os.path.split("c:\music\a.mp3")
split函數(shù)用來(lái)將一個(gè)路徑名分成目錄名和文件名. 它返回的是一個(gè)tuple. 用返回的tuple對(duì)(filepath, filename)賦值.
>>> filepath 'c:\music' >>> filename 'a.mp3' >>> (a, b) = os.path.splitext("a.mp3")
類(lèi)似的. 這個(gè)splitext用來(lái)將一個(gè)全文件名分成 文件名 和 擴(kuò)展名 兩部分.
>>> a 'a' >>> b '.mp3'
列出目錄用:
>>> os.listdir("c:\")
這個(gè)函數(shù)將返回一個(gè)字符串list. 包括所有的文件和文件夾的名字.
['boot.ini', 'CONFIG.SYS', 'AUTOEXEC.BAT', 'java', 等]
要判斷一個(gè)字符串路徑到底是一個(gè)文件還是一個(gè)文件夾. 用os.path模塊中的 isfile() 或 isdir(). 如:
>>> [f for f in os.listdir("c:") if os.path.isdir(os.path.join("c:", f))]
這樣就打印出c中所有文件夾名構(gòu)成的list.
如果要在目錄操作中使用通配符. 可以如下:
>>> import glob
要先導(dǎo)入 glob 模塊
>>> glob.glob('c:\music\*.mp3')
則返回的list中包含了該目錄下所有的 .mp3 后綴的文件名.
更多關(guān)于Python相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《Python文件與目錄操作技巧匯總》、《Python圖片操作技巧總結(jié)》、《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python Socket編程技巧總結(jié)》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》、《Python編碼操作技巧總結(jié)》及《Python入門(mén)與進(jìn)階經(jīng)典教程》
希望本文所述對(duì)大家Python程序設(shè)計(jì)有所幫助。
相關(guān)文章
Python爬取微信讀書(shū)實(shí)現(xiàn)讀書(shū)免費(fèi)自由
主要跟大家介紹一下,我是如何用Python爬取小說(shuō),再導(dǎo)入微信讀書(shū)的。成功實(shí)現(xiàn)在微信讀書(shū)中各種“白票”付費(fèi)小說(shuō),有需要的朋友可以借鑒參考下2021-09-09Python+?Flask實(shí)現(xiàn)Mock?Server詳情
這篇文章主要介紹了Python+?Flask實(shí)現(xiàn)Mock?Server詳情,文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-09-09python中的循環(huán)結(jié)構(gòu)問(wèn)題
這篇文章主要介紹了python中的循環(huán)結(jié)構(gòu)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03基于Python實(shí)現(xiàn)蒙特卡洛法計(jì)算圓周率π
蒙特卡羅法也稱(chēng)統(tǒng)計(jì)模擬法、統(tǒng)計(jì)試驗(yàn)法,是把概率現(xiàn)象作為研究對(duì)象的數(shù)值模擬方法,是按抽樣調(diào)查法求取統(tǒng)計(jì)值來(lái)推定未知特性量的計(jì)算方法,本文我們將介紹如何使用Python來(lái)實(shí)現(xiàn)蒙特卡洛法計(jì)算圓周率π,感興趣的朋友可以參考下2023-06-06Python 實(shí)現(xiàn)Mac 屏幕截圖詳解
今天小編就為大家分享一篇對(duì)Python 實(shí)現(xiàn)Mac 屏幕截圖詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-10-10