日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

Python基础教程(八):日期和时间、文件I/O、异常处理

發布時間:2025/3/21 python 19 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Python基础教程(八):日期和时间、文件I/O、异常处理 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

Python 日期和時間

Python程序能用很多方式處理日期和時間。轉換日期格式是一個常見的例行瑣事。Python有一個 time 和 calendar 模組可以幫忙。


什么是Tick?

時間間隔是以秒為單位的浮點小數。

每個時間戳都以自從1970年1月1日午夜(歷元)經過了多長時間來表示。

Python附帶的受歡迎的time模塊下有很多函數可以轉換常見日期格式。如函數time.time()用ticks計時單位返回從12:00am, January 1, 1970(epoch) 開始的記錄的當前操作系統時間, 如下實例:

#!/usr/bin/python

import time;? #This is required to include time module.

?

ticks = time.time()

print "Number of ticks since 12:00am, January 1,1970:", ticks

以上實例輸出結果:

Number of ticks since 12:00am, January 1, 1970: 7186862.73399

Tick單位最適于做日期運算。但是1970年之前的日期就無法以此表示了。太遙遠的日期也不行,UNIX和Windows只支持到2038年某日。

?


什么是時間元組?

很多Python函數用一個元組裝起來的9組數字處理時間:

<td0到59<td=""></td0到59<>

序號

字段

0

4位數年

2008

1

1 到 12

2

1到31

3

小時

0到23

4

分鐘

?

5

0到61 (60或61 是閏秒)

6

一周的第幾日

0到6 (0是周一)

7

一年的第幾日

1到366 (儒略歷)

8

夏令時

-1, 0, 1, -1是決定是否為夏令時的旗幟

上述也就是struct_time元組。這種結構具有如下屬性:

序號

屬性

0

tm_year

2008

1

tm_mon

1 到 12

2

tm_mday

1 到 31

3

tm_hour

0 到 23

4

tm_min

0 到 59

5

tm_sec

0 到 61 (60或61 是閏秒)

6

tm_wday

0到6 (0是周一)

7

tm_yday

1 到 366(儒略歷)

8

tm_isdst

-1, 0, 1, -1是決定是否為夏令時的旗幟

?


獲取當前時間

從返回浮點數的時間輟方式向時間元組轉換,只要將浮點數傳遞給如localtime之類的函數。

#!/usr/bin/python

import time;

?

localtime = time.localtime(time.time())

print "Local current time :", localtime

以上實例輸出結果:

Local current time : time.struct_time(tm_year=2013,tm_mon=7,

tm_mday=17, tm_hour=21, tm_min=26, tm_sec=3, tm_wday=2,tm_yday=198, tm_isdst=0)

?


獲取格式化的時間

你可以根據需求選取各種格式,但是最簡單的獲取可讀的時間模式的函數是asctime():

#!/usr/bin/python

import time;

?

localtime = time.asctime( time.localtime(time.time()) )

print "Local current time :", localtime

以上實例輸出結果:

Local current time : Tue Jan 13 10:17:09 2009

?


獲取某月日歷

Calendar模塊有很廣泛的方法用來處理年歷和月歷,例如打印某月的月歷:

#!/usr/bin/python

import calendar

?

cal = calendar.month(2008, 1)

print "Here is the calendar:"

print cal;

以上實例輸出結果:

Here is the calendar:

??? January 2008

Mo Tu We Th Fr Sa Su

??? 1? 2? 3? 4? 5? 6

?7? 8? 9 1011 12 13

14 15 16 17 18 19 20

21 22 23 24 25 26 27

28 29 30 31

?


Time模塊

Time模塊包含了以下內置函數,既有時間處理相的,也有轉換時間格式的:

序號

函數及描述

1

time.altzone
返回格林威治西部的夏令時地區的偏移秒數。如果該地區在格林威治東部會返回負值(如西歐,包括英國)。對夏令時啟用地區才能使用。

2

time.asctime([tupletime])
接受時間元組并返回一個可讀的形式為"Tue Dec 11 18:07:14 2008"(2008年12月11日?周二18時07分14秒)的24個字符的字符串。

3

time.clock( )
用以浮點數計算的秒數返回當前的CPU時間。用來衡量不同程序的耗時,比time.time()更有用。

4

time.ctime([secs])
作用相當于asctime(localtime(secs)),未給參數相當于asctime()

5

time.gmtime([secs])
接收時間輟(1970紀元后經過的浮點秒數)并返回格林威治天文時間下的時間元組t。注:t.tm_isdst始終為0

6

time.localtime([secs])
接收時間輟(1970紀元后經過的浮點秒數)并返回當地時間下的時間元組t(t.tm_isdst可取0或1,取決于當地當時是不是夏令時)。

7

time.mktime(tupletime)
接受時間元組并返回時間輟(1970紀元后經過的浮點秒數)。

8

time.sleep(secs)
推遲調用線程的運行,secs指秒數。

9

time.strftime(fmt[,tupletime])
接收以時間元組,并返回以可讀字符串表示的當地時間,格式由fmt決定。

10

time.strptime(str,fmt='%a %b %d %H:%M:%S %Y')
根據fmt的格式把一個時間字符串解析為時間元組。

11

time.time( )
返回當前時間的時間戳(1970紀元后經過的浮點秒數)。

12

time.tzset()
根據環境變量TZ重新初始化時間相關設置。

Time模塊包含了以下2個非常重要的屬性:

序號

屬性及描述

1

time.timezone
屬性time.timezone是當地時區(未啟動夏令時)距離格林威治的偏移秒數(>0,美洲;<=0大部分歐洲,亞洲,非洲)。

2

time.tzname
屬性time.tzname包含一對根據情況的不同而不同的字符串,分別是帶夏令時的本地時區名稱,和不帶的。

?


日歷(Calendar)模塊

此模塊的函數都是日歷相關的,例如打印某月的字符月歷。

星期一是默認的每周第一天,星期天是默認的最后一天。更改設置需調用calendar.setfirstweekday()函數。模塊包含了以下內置函數:

序號

函數及描述

1

calendar.calendar(year,w=2,l=1,c=6)
返回一個多行字符串格式的year年年歷,3個月一行,間隔距離為c。 每日寬度間隔為w字符。每行長度為21* W+18+2* C。l是每星期行數。

2

calendar.firstweekday( )
返回當前每周起始日期的設置。默認情況下,首次載入caendar模塊時返回0,即星期一。

3

calendar.isleap(year)
是閏年返回True,否則為false。

4

calendar.leapdays(y1,y2)
返回在Y1,Y2兩年之間的閏年總數。

5

calendar.month(year,month,w=2,l=1)
返回一個多行字符串格式的year年month月日歷,兩行標題,一周一行。每日寬度間隔為w字符。每行的長度為7* w+6。l是每星期的行數。

6

calendar.monthcalendar(year,month)
返回一個整數的單層嵌套列表。每個子列表裝載代表一個星期的整數。Year年month月外的日期都設為0;范圍內的日子都由該月第幾日表示,從1開始。

7

calendar.monthrange(year,month)
返回兩個整數。第一個是該月的星期幾的日期碼,第二個是該月的日期碼。日從0(星期一)到6(星期日);月從1到12。

8

calendar.prcal(year,w=2,l=1,c=6)
相當于 print calendar.calendar(year,w,l,c).

9

calendar.prmonth(year,month,w=2,l=1)
相當于 print calendar.calendar(year,w,l,c)。

10

calendar.setfirstweekday(weekday)
設置每周的起始日期碼。0(星期一)到6(星期日)。

11

calendar.timegm(tupletime)
和time.gmtime相反:接受一個時間元組形式,返回該時刻的時間輟(1970紀元后經過的浮點秒數)。

12

calendar.weekday(year,month,day)
返回給定日期的日期碼。0(星期一)到6(星期日)。月份為 1(一月) 到 12(12月)。

?


其他相關模塊和函數

在Python種,其他處理日期和時間的模塊還有:

  • datetime模塊
  • pytz模塊
  • dateutil模塊


Python 文件I/O

本章只講述所有基本的的I/O函數,更多函數請參考Python標準文檔。

打印到屏幕

最簡單的輸出方法是用print語句,你可以給它傳遞零個或多個用逗號隔開的表達式。此函數把你傳遞的表達式轉換成一個字符串表達式,并將結果寫到標準輸出如下:

#!/usr/bin/python # -*- coding: UTF-8 -*- ? print "Python 是一個非常棒的語言,不是嗎?";

你的標準屏幕上會產生以下結果:

Python 是一個非常棒的語言,不是嗎?

讀取鍵盤輸入

Python提供了兩個內置函數從標準輸入讀入一行文本,默認的標準輸入是鍵盤。如下:

  • raw_input
  • input

raw_input函數

raw_input([prompt]) 函數從標準輸入讀取一個行,并返回一個字符串(去掉結尾的換行符):

#!/usr/bin/python str = raw_input("Enter your input: "); print "Received input is : ", str

這將提示你輸入任意字符串,然后在屏幕上顯示相同的字符串。當我輸入"Hello Python!",它的輸出如下:

Enter your input: Hello Python Received input is :? Hello Python

input函數

input([prompt]) 函數和raw_input([prompt])函數基本可以互換,但是input會假設你的輸入是一個有效的Python表達式,并返回運算結果。

#!/usr/bin/python str = input("Enter your input: "); print "Received input is : ", str

這會產生如下的對應著輸入的結果:

Enter your input: [x*5 for x in range(2,10,2)] Recieved input is :? [10, 20, 30, 40]

打開和關閉文件

到現在為止,您已經可以向標準輸入和輸進行讀寫。現在,來看看怎么讀寫實際的數據文件。

Python提供了必要的函數和方法進行默認情況下的文件基本操作。你可以用file對象做大部分的文件操作。

open函數

你必須先用Python內置的open()函數打開一個文件,創建一個file對象,相關的輔助方法才可以調用它進行讀寫。

語法:

file object = open(file_name [, access_mode][, buffering])

各個參數的細節如下:

  • file_name:file_name變量是一個包含了你要訪問的文件名稱的字符串值。
  • access_mode:access_mode決定了打開文件的模式:只讀,寫入,追加等。所有可取值見如下的完全列表。這個參數是非強制的,默認文件訪問模式為只讀(r)。
  • buffering:如果buffering的值被設為0,就不會有寄存。如果buffering的值取1,訪問文件時會寄存行。如果將buffering的值設為大于1的整數,表明了這就是的寄存區的緩沖大小。如果取負值,寄存區的緩沖大小則為系統默認。

不同模式打開文件的完全列表:

模式

描述

r

以只讀方式打開文件。文件的指針將會放在文件的開頭。這是默認模式。

rb

以二進制格式打開一個文件用于只讀。文件指針將會放在文件的開頭。這是默認模式。

r+

打開一個文件用于讀寫。文件指針將會放在文件的開頭。

rb+

以二進制格式打開一個文件用于讀寫。文件指針將會放在文件的開頭。

w

打開一個文件只用于寫入。如果該文件已存在則將其覆蓋。如果該文件不存在,創建新文件。

wb

以二進制格式打開一個文件只用于寫入。如果該文件已存在則將其覆蓋。如果該文件不存在,創建新文件。

w+

打開一個文件用于讀寫。如果該文件已存在則將其覆蓋。如果該文件不存在,創建新文件。

wb+

以二進制格式打開一個文件用于讀寫。如果該文件已存在則將其覆蓋。如果該文件不存在,創建新文件。

a

打開一個文件用于追加。如果該文件已存在,文件指針將會放在文件的結尾。也就是說,新的內容將會被寫入到已有內容之后。如果該文件不存在,創建新文件進行寫入。

ab

以二進制格式打開一個文件用于追加。如果該文件已存在,文件指針將會放在文件的結尾。也就是說,新的內容將會被寫入到已有內容之后。如果該文件不存在,創建新文件進行寫入。

a+

打開一個文件用于讀寫。如果該文件已存在,文件指針將會放在文件的結尾。文件打開時會是追加模式。如果該文件不存在,創建新文件用于讀寫。

ab+

以二進制格式打開一個文件用于追加。如果該文件已存在,文件指針將會放在文件的結尾。如果該文件不存在,創建新文件用于讀寫。

File對象的屬性

一個文件被打開后,你有一個file對象,你可以得到有關該文件的各種信息。

以下是和file對象相關的所有屬性的列表:

屬性

描述

file.closed

返回true如果文件已被關閉,否則返回false。

file.mode

返回被打開文件的訪問模式。

file.name

返回文件的名稱。

file.softspace

如果用print輸出后,必須跟一個空格符,則返回false。否則返回true。

如下實例:

#!/usr/bin/python # -*- coding: UTF-8 -*- # 打開一個文件 fo = open("foo.txt", "wb") print "Name of the file: ", fo.name print "Closed or not : ", fo.closed print "Opening mode : ", fo.mode print "Softspace flag : ", fo.softspace

以上實例輸出結果:

Name of the file:? foo.txt Closed or not :? False Opening mode :? wb Softspace flag :? 0

Close()方法

File對象的close()方法刷新緩沖區里任何還沒寫入的信息,并關閉該文件,這之后便不能再進行寫入。

當一個文件對象的引用被重新指定給另一個文件時,Python會關閉之前的文件。用close()方法關閉文件是一個很好的習慣。

語法:

fileObject.close();

例子:

#!/usr/bin/python # -*- coding: UTF-8 -*- # 打開一個文件 fo = open("foo.txt", "wb") print "Name of the file: ", fo.name # 關閉打開的文件 fo.close()

以上實例輸出結果:

Name of the file:? foo.txt

讀寫文件:

file對象提供了一系列方法,能讓我們的文件訪問更輕松。來看看如何使用read()和write()方法來讀取和寫入文件。

Write()方法

Write()方法可將任何字符串寫入一個打開的文件。需要重點注意的是,Python字符串可以是二進制數據,而不是僅僅是文字。

Write()方法不在字符串的結尾不添加換行符('\n'):

語法:

fileObject.write(string);

在這里,被傳遞的參數是要寫入到已打開文件的內容。

例子:

#!/usr/bin/python # -*- coding: UTF-8 -*- # 打開一個文件 fo = open("/tmp/foo.txt", "wb") fo.write( "Python is a great language.\nYeah its great!!\n"); # 關閉打開的文件 fo.close()

上述方法會創建foo.txt文件,并將收到的內容寫入該文件,并最終關閉文件。如果你打開這個文件,將看到以下內容:

Python is a great language. Yeah its great!!

read()方法

read()方法從一個打開的文件中讀取一個字符串。需要重點注意的是,Python字符串可以是二進制數據,而不是僅僅是文字。

語法:

fileObject.read([count]);

在這里,被傳遞的參數是要從已打開文件中讀取的字節計數。該方法從文件的開頭開始讀入,如果沒有傳入count,它會嘗試盡可能多地讀取更多的內容,很可能是直到文件的末尾。

例子:

就用我們上面創建的文件foo.txt。

#!/usr/bin/python # -*- coding: UTF-8 -*- # 打開一個文件 fo = open("/tmp/foo.txt", "r+") str = fo.read(10); print "Read String is : ", str # 關閉打開的文件 fo.close()

以上實例輸出結果:

Read String is :? Python is

文件位置:

Tell()方法告訴你文件內的當前位置;換句話說,下一次的讀寫會發生在文件開頭這么多字節之后:

seek(offset [,from])方法改變當前文件的位置。Offset變量表示要移動的字節數。From變量指定開始移動字節的參考位置。

如果from被設為0,這意味著將文件的開頭作為移動字節的參考位置。如果設為1,則使用當前的位置作為參考位置。如果它被設為2,那么該文件的末尾將作為參考位置。

例子:

就用我們上面創建的文件foo.txt。

#!/usr/bin/python # -*- coding: UTF-8 -*- # 打開一個文件 fo = open("/tmp/foo.txt", "r+") str = fo.read(10); print "Read String is : ", str # 查找當前位置 position = fo.tell(); print "Current file position : ", position # 把指針再次重新定位到文件開頭 position = fo.seek(0, 0); str = fo.read(10); print "Again read String is : ", str # 關閉打開的文件 fo.close()

以上實例輸出結果:

Read String is :? Python is Current file position :? 10 Again read String is :? Python is

重命名和刪除文件

Python的os模塊提供了幫你執行文件處理操作的方法,比如重命名和刪除文件。

要使用這個模塊,你必須先導入它,然后可以調用相關的各種功能。

rename()方法:

rename()方法需要兩個參數,當前的文件名和新文件名。

語法:

os.rename(current_file_name, new_file_name)

例子:

下例將重命名一個已經存在的文件test1.txt。

#!/usr/bin/python # -*- coding: UTF-8 -*- ? import os # 重命名文件test1.txt到test2.txt。 os.rename( "test1.txt", "test2.txt" )

remove()方法

你可以用remove()方法刪除文件,需要提供要刪除的文件名作為參數。

語法:

os.remove(file_name)

例子:

下例將刪除一個已經存在的文件test2.txt。

#!/usr/bin/python # -*- coding: UTF-8 -*- ? import os # 刪除一個已經存在的文件test2.txt os.remove("test2.txt")

Python里的目錄:

所有文件都包含在各個不同的目錄下,不過Python也能輕松處理。os模塊有許多方法能幫你創建,刪除和更改目錄。

mkdir()方法

可以使用os模塊的mkdir()方法在當前目錄下創建新的目錄們。你需要提供一個包含了要創建的目錄名稱的參數。

語法:

os.mkdir("newdir")

例子:

下例將在當前目錄下創建一個新目錄test。

#!/usr/bin/python # -*- coding: UTF-8 -*- ? import os # 創建目錄test os.mkdir("test")

chdir()方法

可以用chdir()方法來改變當前的目錄。chdir()方法需要的一個參數是你想設成當前目錄的目錄名稱。

語法:

os.chdir("newdir")

例子:

下例將進入"/home/newdir"目錄。

#!/usr/bin/python # -*- coding: UTF-8 -*- ? import os # 將當前目錄改為"/home/newdir" os.chdir("/home/newdir")

getcwd()方法:

getcwd()方法顯示當前的工作目錄。

語法:

os.getcwd()

例子:

下例給出當前目錄:

#!/usr/bin/python # -*- coding: UTF-8 -*- ? import os # 給出當前的目錄 os.getcwd()

rmdir()方法

rmdir()方法刪除目錄,目錄名稱以參數傳遞。

在刪除這個目錄之前,它的所有內容應該先被清除。

語法:

os.rmdir('dirname')

例子:

以下是刪除" /tmp/test"目錄的例子。目錄的完全合規的名稱必須被給出,否則會在當前目錄下搜索該目錄。

#!/usr/bin/python # -*- coding: UTF-8 -*- ? import os # 刪除”/tmp/test”目錄 os.rmdir( "/tmp/test"? )

文件、目錄相關的方法

三個重要的方法來源能對Windows和Unix操作系統上的文件及目錄進行一個廣泛且實用的處理及操控,如下:

  • File 對象方法: file對象提供了操作文件的一系列方法。
  • OS 對象方法: 提供了處理文件及目錄的一系列方法。

?

?

Python 異常處理

python提供了兩個非常重要的功能來處理python程序在運行中出現的異常和錯誤。你可以使用該功能來調試python程序。

  • 異常處理: 本站Python教程會具體介紹。
  • 斷言(Assertions):本站Python教程會具體介紹。

python標準異常

異常名稱

描述

??

BaseException

所有異常的基類

SystemExit

解釋器請求退出

KeyboardInterrupt

用戶中斷執行(通常是輸入^C)

Exception

常規錯誤的基類

StopIteration

迭代器沒有更多的值

GeneratorExit

生成器(generator)發生異常來通知退出

StandardError

所有的內建標準異常的基類

ArithmeticError

所有數值計算錯誤的基類

FloatingPointError

浮點計算錯誤

OverflowError

數值運算超出最大限制

ZeroDivisionError

除(或取模)零 (所有數據類型)

AssertionError

斷言語句失敗

AttributeError

對象沒有這個屬性

EOFError

沒有內建輸入,到達EOF 標記

EnvironmentError

操作系統錯誤的基類

IOError

輸入/輸出操作失敗

OSError

操作系統錯誤

WindowsError

系統調用失敗

ImportError

導入模塊/對象失敗

LookupError

無效數據查詢的基類

IndexError

序列中沒有此索引(index)

KeyError

映射中沒有這個鍵

MemoryError

內存溢出錯誤(對于Python 解釋器不是致命的)

NameError

未聲明/初始化對象 (沒有屬性)

UnboundLocalError

訪問未初始化的本地變量

ReferenceError

弱引用(Weak reference)試圖訪問已經垃圾回收了的對象

RuntimeError

一般的運行時錯誤

NotImplementedError

尚未實現的方法

SyntaxError

Python 語法錯誤

IndentationError

縮進錯誤

TabError

Tab 和空格混用

SystemError

一般的解釋器系統錯誤

TypeError

對類型無效的操作

ValueError

傳入無效的參數

UnicodeError

Unicode 相關的錯誤

UnicodeDecodeError

Unicode 解碼時的錯誤

UnicodeEncodeError

Unicode 編碼時錯誤

UnicodeTranslateError

Unicode 轉換時錯誤

Warning

警告的基類

DeprecationWarning

關于被棄用的特征的警告

FutureWarning

關于構造將來語義會有改變的警告

OverflowWarning

舊的關于自動提升為長整型(long)的警告

PendingDeprecationWarning

關于特性將會被廢棄的警告

RuntimeWarning

可疑的運行時行為(runtime behavior)的警告

SyntaxWarning

可疑的語法的警告

UserWarning

用戶代碼生成的警告

什么是異常?

異常即是一個事件,該事件會在程序執行過程中發生,影響了程序的正常執行。

一般情況下,在Python無法正常處理程序時就會發生一個異常。

異常是Python對象,表示一個錯誤。

當Python腳本發生異常時我們需要捕獲處理它,否則程序會終止執行。


異常處理

捕捉異常可以使用try/except語句。

try/except語句用來檢測try語句塊中的錯誤,從而讓except語句捕獲異常信息并處理。

如果你不想在異常發生時結束你的程序,只需在try里捕獲它。

語法:

以下為簡單的try....except...else的語法:

try: <語句>??????? #運行別的代碼 except <名字>: <語句>??????? #如果在try部份引發了'name'異常 except <名字>,<數據>: <語句>??????? #如果引發了'name'異常,獲得附加的數據 else: <語句>??????? #如果沒有異常發生

try的工作原理是,當開始一個try語句后,python就在當前程序的上下文中作標記,這樣當異常出現時就可以回到這里,try子句先執行,接下來會發生什么依賴于執行時是否出現異常。

  • 如果當try后的語句執行時發生異常,python就跳回到try并執行第一個匹配該異常的except子句,異常處理完畢,控制流就通過整個try語句(除非在處理異常時又引發新的異常)。
  • 如果在try后的語句里發生了異常,卻沒有匹配的except子句,異常將被遞交到上層的try,或者到程序的最上層(這樣將結束程序,并打印缺省的出錯信息)。
  • 如果在try子句執行時沒有發生異常,python將執行else語句后的語句(如果有else的話),然后控制流通過整個try語句。

實例

下面是簡單的例子,它打開一個文件,在該文件中的內容寫入內容,且并未發生異常:

#!/usr/bin/python ? try: ?? fh = open("testfile", "w") ?? fh.write("This is my test file for exception handling!!") except IOError: ?? print "Error: can\'t find file or read data" else: ?? print "Written content in the file successfully" ?? fh.close()

以上程序輸出結果:

?Written content in the file successfully

實例

下面是簡單的例子,它打開一個文件,在該文件中的內容寫入內容,但文件沒有寫入權限,發生了異常:

#!/usr/bin/python ? try: ?? fh = open("testfile", "w") ?? fh.write("This is my test file for exception handling!!") except IOError: ?? print "Error: can\'t find file or read data" else: ?? print "Written content in the file successfully"

以上程序輸出結果:

Error: can't find file or read data

使用except而不帶任何異常類型

你可以不帶任何異常類型使用except,如下實例:

try: ?? You do your operations here; ?? ...................... except: ?? If there is any exception, then execute this block. ?? ...................... else: ?? If there is no exception then execute this block.

以上方式try-except語句捕獲所有發生的異常。但這不是一個很好的方式,我們不能通過該程序識別出具體的異常信息。因為它捕獲所有的異常。


使用except而帶多種異常類型

你也可以使用相同的except語句來處理多個異常信息,如下所示:

try: ?? You do your operations here; ?? ...................... except(Exception1[, Exception2[,...ExceptionN]]]): ?? If there is any exception from the given exception list, ???then execute this block. ?? ...................... else: ?? If there is no exception then execute this block.?

try-finally 語句

try-finally 語句無論是否發生異常都將執行最后的代碼。

try: <語句> finally: <語句>??? #退出try時總會執行 raise

實例

#!/usr/bin/python ? try: ?? fh = open("testfile", "w") ?? fh.write("This is my test file for exception handling!!") finally: ?? print "Error: can\'t find file or read data"

如果打開的文件沒有可寫權限,輸出如下所示:

Error: can't find file or read data

同樣的例子也可以寫成如下方式:

#!/usr/bin/python ? try: ?? fh = open("testfile", "w") ?? try: ????? fh.write("This is my test file for exception handling!!") ?? finally: ????? print "Going to close the file" ????? fh.close() except IOError: ?? print "Error: can\'t find file or read data"

當在try塊中拋出一個異常,立即執行finally塊代碼。

finally塊中的所有語句執行后,異常被再次提出,并執行except塊代碼。

參數的內容不同于異常。


異常的參數

一個異常可以帶上參數,可作為輸出的異常信息參數。

你可以通過except語句來捕獲異常的參數,如下所示:

try: ?? You do your operations here; ?? ...................... except ExceptionType, Argument: ?? You can print value of Argument here...

變量接收的異常值通常包含在異常的語句中。在元組的表單中變量可以接收一個或者多個值。

元組通常包含錯誤字符串,錯誤數字,錯誤位置。

實例

以下為單個異常的實例:

#!/usr/bin/python ? # Define a function here. def temp_convert(var): ?? try: ????? return int(var) ?? except ValueError, Argument: ????? print "The argument does not contain numbers\n", Argument ? # Call above function here. temp_convert("xyz");

以上程序執行結果如下:

The argument does not contain numbers invalid literal for int() with base 10: 'xyz'

觸發異常

我們可以使用raise語句自己觸發異常

raise語法格式如下:

raise [Exception [, args [, traceback]]]

語句中Exception是異常的類型(例如,NameError)參數是一個異常參數值。該參數是可選的,如果不提供,異常的參數是"None"。

最后一個參數是可選的(在實踐中很少使用),如果存在,是跟蹤異常對象。

實例

一個異常可以是一個字符串,類或對象。 Python的內核提供的異常,大多數都是實例化的類,這是一個類的實例的參數。

定義一個異常非常簡單,如下所示:

def functionName( level ): ?? if level < 1: ????? raise "Invalid level!", level ????? # The code below to this would not be executed ????? # if we raise the exception

注意:為了能夠捕獲異常,"except"語句必須有用相同的異常來拋出類對象或者字符串。

例如我們捕獲以上異常,"except"語句如下所示:

try: ?? Business Logic here... except "Invalid level!": ?? Exception handling here... else: ?? Rest of the code here...

用戶自定義異常

通過創建一個新的異常類,程序可以命名它們自己的異常。異常應該是典型的繼承自Exception類,通過直接或間接的方式。

以下為與RuntimeError相關的實例,實例中創建了一個類,基類為RuntimeError,用于在異常觸發時輸出更多的信息。

在try語句塊中,用戶自定義的異常后執行except塊語句,變量 e 是用于創建Networkerror類的實例。

class Networkerror(RuntimeError): ?? def __init__(self, arg): ????? self.args = arg

在你定義以上類后,你可以觸發該異常,如下所示:

try: ?? raise Networkerror("Bad hostname") except Networkerror,e: ?? print e.args

出處:http://www.runoob.com/python/python-tutorial.html

總結

以上是生活随笔為你收集整理的Python基础教程(八):日期和时间、文件I/O、异常处理的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 日本一二三区视频 | 一起操网址 | 国产欧美精品久久 | 一级欧美一级日韩 | 亚洲综合精品 | 住在隔壁的她动漫免费观看全集下载 | 国产乱子伦一区二区 | 少妇被按摩师摸高潮了 | 三级免费看 | 午夜少妇av| 黄色a级免费 | 亚洲精品777 | 欧美成人r级一区二区三区 中文无码一区二区三区在线观看 | 国产综合自拍 | 高清中文字幕av | 成人音影 | 亚洲欧美另类激情 | 人妻精品久久久久中文字幕 | 黄色av片三级三级三级免费看 | 免费不卡的av | 国产av 一区二区三区 | 很很干很很日 | 亚洲视频在线免费看 | 美女视频在线观看免费 | 国产91高清 | 电影《走路上学》免费 | 在线伊人网 | 欧美日韩亚洲二区 | 日本免费一区二区三区 | 欧美激情在线一区二区 | 欧美日韩在线免费观看 | 日韩视频在线免费 | 在线观看日批 | 女生被草 | 韩国av在线免费观看 | 日韩有码av | 久久鲁鲁| 国产成人一区二区三区小说 | 国产夜夜操 | 日韩新片王网 | exo妈妈mv在线播放高清免费 | 国产欧美一区二区三区沐欲 | 久久av无码精品人妻出轨 | 免费在线亚洲 | 亚洲四区 | 麻豆极品 | 92久久精品一区二区 | 精品人妻一区二区三区视频 | 欧美日韩一区二区三区在线 | 亚洲伦理网 | 国产精品一色哟哟哟 | 极品新婚夜少妇真紧 | 一级理论片 | 邪恶久久| 乌克兰做爰xxxⅹ性视频 | 天天干夜夜做 | 日本高清不卡一区 | 午夜小福利 | 免费在线色视频 | 极品美妇后花庭翘臀娇吟小说 | 亚洲 高清 成人 动漫 | 日本高清三区 | 精品人妻一区二区三区蜜桃 | 国产精品久久久久aaaa | 国产在线观看免费av | 日韩在线观看免费全 | 综合久久激情 | 国产精品精品久久久久久 | 91浏览器在线观看 | 国产尤物av尤物在线看 | 我的公把我弄高潮了视频 | 欧美另类第一页 | 国产毛片久久久久久久 | 首尔之春在线看 | 激情伦成人综合小说 | 国产成人无码精品久久久久 | 国产成人精品亚洲日本在线观看 | 国内av自拍 | 伊人影院在线观看视频 | 男女插鸡视频 | 国产精品国产三级国产普通话对白 | 手机亚洲第一页 | av网站观看 | 久久中文字幕无码 | 国产亚洲精品久久久久动 | 在线免费看av片 | 这里只有精品视频 | 男生和女生一起差差差很痛的视频 | jizz美女| 我爱avav色aⅴ爱avav | 国产视频手机在线观看 | 97伦伦午夜电影理伦片 | 亚洲精品久久久久久国产精华液 | 在线观看亚洲 | 特黄特色大片免费视频大全 | 中文字幕人妻丝袜乱一区三区 | 91小视频在线观看 | 亚欧中文字幕 | 亚洲黄色免费在线观看 |