本文執行個體講述了python異常和檔案處理機制。分享給大家供大家參考,具體如下:
1 異常處理
Python的異常用
try
except
finally
來處理. 並且except後還可以跟 else .
引發異常用 raise
如果拋出的異常沒有被處理. 在Python IDE中是顯示一些紅色的資訊. 在真正的Python程式運行時. 會導致程式終止.
在以前我們已經見到過一下幾種異常:
在 Dictionary 中如果使用的 key 不存在. 會引發 KeyError 異常. 如:
>>> d = {"a":1, "b":"abc"}>>> d["c"]Traceback (most recent call last): File "", line 1, in KeyError: 'c'
搜尋列表中不存在的值. 將引發 ValueError 異常. 如:
>>> li = [1,2]>>> li.index(3)Traceback (most recent call last): File "", line 1, in ValueError: list.index(x): x not in list
對應的. 若用下標來引用列表中的元素. 若下標出界. 會產生 IndexError 異常. 如:
>>> li[2]Traceback (most recent call last): File "", line 1, in IndexError: list index out of range
調用不存在的方法. 會引發 AttributeError 異常.
引用不存在的變數. 引發 NameError 異常.
未強制轉化就混用資料類型. 引發 TypeError 異常.
檔案操作錯誤引發的 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 是一個內建函數. 用來開啟檔案. 並返回一個檔案對象.
try except 後邊可以跟 else 語句. 當沒有捕捉到指定的異常時. 執行else 語句.
匯入一個模組時. 若模組不存在. 會引發 ImportError 異常.
還可以定義自己的異常類. 定義時讓它繼承內建的 Exception 類. 然後在需要拋出異常時用 raise 拋出.
2 與檔案對象共事
前面說過用 open 可以開啟檔案並返迴文件對象. 它的函式宣告如下:
open(name[, mode[, buffering]])
有3個參數(其中後兩個是可選的). 分別表示 檔案名稱. 開啟檔案. 緩衝區參數. 例如:
>>> f = open("/music/_singles/kairo.mp3", "rb")
第2個參數指定為"rb". 表示以2進位讀開啟檔案. 如果這個參數預設. 則表示以文本方式開啟.
如果不能開啟. 則open引發 IOError 異常.
現在可以用檔案對象的 name 屬性和 mode 屬性來查詢它們. 如:
>>> f.name'/music/_singles/kairo.mp3'>>> f.mode'rb'
開啟檔案後. 就可以進行讀寫了. 如:
>>> f.tell()
查詢當前位置.
0>>> f.seek(0, 2)
定位檔案指標. 第一個參數是位移值. 第二個可以取0. 1. 2三個值. 分別表示開頭. 當前位置. 末尾.
若定位的地址不正確(例如超過範圍) 則引發IOError異常.
所以這個語句就把檔案指標定位到了檔案尾.
>>> f.tell()
這將列印檔案的長度.
>>> f.seek(-128, 2)>>> data = f.read(128)
讀取檔案的最後128位元組. 並將讀入的的資料作為字串返回. 讀取資料時也同時後移檔案指標.
其中 read 的參數表示最大讀取位元組數. 也可以省略這個參數. 則表示一直讀到檔案末尾.
若讀取時出現錯誤(如磁碟上有壞扇區或網路已斷開). 引發IOError 異常.
>>> f.closed
查看檔案是否關閉.
False>>> f.close()
不再使用時應該關閉檔案. 可以對一個已經關閉的檔案再次關閉(不會發生異常).
>>> f.closedTrue
關閉之後如果再對 f 進行 seek() 等操作. 會引發 ValueError 異常.
寫入檔案的辦法和讀取類似. 不過它要求檔案是 "寫" 開啟的. 如:
>>> f1 = open('test.log', 'w')
其中 'w' 表示寫開啟. 這樣即使檔案不存在. 也會建立. 如果存在. 則覆蓋現有的檔案.
>>> f1.write('abc')>>> f1.close()>>> file('test.log').read()
用 file()開啟檔案和用open()開啟是一樣的. 所以列印:
'abc'
3 for迴圈
在Python中. for用來在一個List上遍曆. 如:
>>> li = [1, 2, 3]>>> for i in li:
這會在迴圈中讓 i 依次接收 li 中的元素的值.
... print i
...
1
2
3
這個輸出和 print "\n".joni(li) 一樣.
如果要象其它語言中一樣. 讓for做計數使用. 可以用如下的辦法:
>>> for i in range(len(li)) : print li[i]...123
要用 for 來遍曆 Dictionary . 如下:
>>> d = {1:"abc", 2:"def"}>>> for k, v in d.items() : print "%d = %s" % (k, v)...1 = abc2 = def
上邊的列印結果和 print "\n".join(["%d = %s" % (k, v) for k, v in d.items()]) 一樣.
4 使用 sys.modules
在Python中. modules 是定義在sys模組中的一個全域的字典對象.
一旦我們import一個模組. 就可以在 sys.modules 中找到它.
每個類都擁有一個內建的"類屬性" : __module__ . 其值為定義該類的模組的名字.
5 與Directory共事
在os.path 所引用的模組中有幾個操作檔案和目錄的函數.如:
>>> import os>>> os.path.join("c:\music", "mahadeva.mp3")
這個join函數用來將一個或多個字串構造成一個路徑名.
'c:\music\mahadeva.mp3'>>> os.path.expanduser("~")
expanduser函數用'~'作參數時. 返回目前使用者根目錄.
'c:\Documents and Settings\mpilgrim\My Documents'
>>> (filepath, filename) = os.path.split("c:\music\a.mp3")
split函數用來將一個路徑名分成目錄名和檔案名稱. 它返回的是一個tuple. 用返回的tuple對(filepath, filename)賦值.
>>> filepath'c:\music'>>> filename'a.mp3'>>> (a, b) = os.path.splitext("a.mp3")
類似的. 這個splitext用來將一個全檔案名稱分成 檔案名稱 和 副檔名 兩部分.
>>> a'a'>>> b'.mp3'
列出目錄用:
>>> os.listdir("c:\")
這個函數將返回一個字串list. 包括所有的檔案和檔案夾的名字.
['boot.ini', 'CONFIG.SYS', 'AUTOEXEC.BAT', 'java', 等]
要判斷一個字串路徑到底是一個檔案還是一個檔案夾. 用os.path模組中的 isfile() 或 isdir(). 如:
>>> [f for f in os.listdir("c:") if os.path.isdir(os.path.join("c:", f))]
這樣就列印出c中所有檔案夾名構成的list.
如果要在目錄操作中使用萬用字元. 可以如下:
>>> import glob
要先匯入 glob 模組
>>> glob.glob('c:\music\*.mp3')
則返回的list中包含了該目錄下所有的 .mp3 尾碼的檔案名稱.
更多關於Python相關內容感興趣的讀者可查看本站專題:《Python檔案與目錄操作技巧匯總》、《Python圖片操作技巧總結》、《Python資料結構與演算法教程》、《Python Socket編程技巧總結》、《Python函數提示總結》、《Python字串操作技巧匯總》、《Python編碼操作技巧總結》及《Python入門與進階經典教程》
希望本文所述對大家Python程式設計有所協助。