您好,登錄后才能下訂單哦!
這篇文章主要介紹了Python中復合語句怎么使用的相關(guān)知識,內(nèi)容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇Python中復合語句怎么使用文章都會有所收獲,下面我們一起來看看吧。
復合語句是包含其它語句(語句組)的語句;它們會以某種方式影響或控制所包含其它語句的執(zhí)行。通常,復合語句會跨越多行,雖然在某些簡單形式下整個復合語句也可能包含于一行之內(nèi)。
if、while和for語句用來實現(xiàn)傳統(tǒng)的控制流程構(gòu)造。try語句為一組語句指定異常處理和/和清理代碼,而with語句允許在一個代碼塊周圍執(zhí)行初始化和終結(jié)化代碼。
函數(shù)和類定義在語法上也屬于復合語句。
一條復合語句由一個或多個子句組成。一個子句則包含一個句頭和一個句體。特定復合語句的子句頭都處于相同的縮進層級。
每個子句頭以一個作為唯一標識的關(guān)鍵字開始并以一個冒號結(jié)束。
子句體是由一個子句控制的一組語句。子句體可以是在子句頭的冒號之后與其同處一行的一條或由分號分隔的多條簡單語句,或者也可以是在其之后縮進的一行或多行語句。只有后一種形式的子句體才能包含嵌套的復合語句。
if 語句用于有條件地執(zhí)行。if語句的一般語法格式如下:
if 條件表達式:
子句體1
[elif 條件表達式:
子句體2]* # *號代表該字句可以是0或多個,下同
[else:
子句體3]
if語句通過對條件表達式進行求值,如果為真則執(zhí)行相應的子句體,如果全都為假,可選的else子句體將會被執(zhí)行。
注意:
1、False、None、0、""、()、[]、{}`都視為假
while 語句用于在表達式保持為真的情況下重復地執(zhí)行,一般語法格式為:
while 條件表達式:
子句體1
[else:
子句體2]
while語句會重復地檢驗表達式,并且如果其值為真就執(zhí)行子句體1;如果表達式值為假(這可能在第一次檢驗時就發(fā)生),則可選的else子句體將會被執(zhí)行。
如果在第一個子句體中使用了break語句,則將終止循環(huán)且不執(zhí)行 else 子句體。
如果在第一個子句體中使用了continue 語句,則在執(zhí)行時將跳過子句體中的剩余部分并返回檢驗表達式。
示例:求1-100整數(shù)的和
b = 0 s = 0 while b < 100: b += 1 s += b print(s)
輸出:
5050
實例:判斷某個數(shù)是否是質(zhì)數(shù)?
num = 87 i = 2 while i < num: if num % i == 0: print(f'{num} 不是質(zhì)數(shù)') break i += 1 else: print(f'{num} 是質(zhì)數(shù)')
輸出:
87 不是質(zhì)數(shù)
for 語句用于對序列(例如字符串、元組或列表)或其他可迭代對象中的元素進行迭代,一般語法格式為:
for 變量 in 序列:
子句體1
[else:
子句體2]
for語句會每次從序列中拿一個元素出來并賦值給變量,然后執(zhí)行子句體1。當序列中所有的元素都獲取完畢后,則可選的else子句體將會被執(zhí)行。
和While語句一樣,如果在子句體1中使用了break語句,則將終止循環(huán)且不執(zhí)行 else 子句體。
如果在子句體1中使用continue 語句,則在執(zhí)行時將跳過子句體中的剩余部分并返回檢驗表達式。如果此時沒有下一項,則會執(zhí)行else子句體(如果存在else子句的話)。
示例
langs = ['c', 'c++', 'python', 'java'] for i in langs: print(i)
輸出:
c
c++
python
java
說明:
1、for 循環(huán)會對目標列表中的變量進行賦值。這將覆蓋之前對這些變量的所有賦值,包括在 for 循環(huán)體中的賦值,所以我們不能通過修改循環(huán)變量的值來達到修改循環(huán)次數(shù)的目的。
for i in [1, 2, 3]: print(i) i = 5
2、在使用for循環(huán)中,循環(huán)變量名最好用_開頭的變量名,甚至直接就用_這樣的變量名,這樣就不會和外部變量名稱沖突。
3、for循環(huán)經(jīng)常搭配range函數(shù)使用。range函數(shù)可以生成一系列的整型數(shù)字。比如:range(5)可以生成:0,1,2,3,4。
try語句可以用來捕獲一組語句中指定的異常并處理,也可以用來清理代碼。try語句有兩種語法格式。
格式一:用來清理代碼
try:
子句體1
finally:
子句體2
子句體1中的語句將會一條一條的執(zhí)行,如果某條語句報錯,則跳過子句體1中剩下的其他語句,直接執(zhí)行子句體2中的語句。
格式二:用來捕獲異常并處理
try:
子句體1
[except 異常1: 或 except (異常1, 異常2):
子句體2]*
[else:
子句體3]
[finally:
子句體4]
語句塊1中的語句將會一條一條的執(zhí)行,如果某條語句報錯,則跳過語句塊1中剩下的其他語句,然后根據(jù)異常原因到except語句中匹配異常,如果匹配到了,則執(zhí)行相應的語句塊2中的語句。
如果try子句中的語句塊1沒有引發(fā)異常,也沒有執(zhí)行return、continue或break語句,那么可選的else子句將會被執(zhí)行。并且else子句中的異常不會被except子句捕獲并處理。
而無論情況如何,finally子句體在try語句結(jié)束前總會被執(zhí)行。
1、可以通過sys.exc_info()來訪問異常的詳細信息。返回一個 3 元組,由異常類、異常實例和回溯對象組成。如下:
import sys print(sys.exc_info()) try: 5 + '5' except: print(sys.exc_info())
輸出:
(None, None, None)
(<class 'TypeError'>, TypeError("unsupported operand type(s) for +: 'int' and 'str'"), <traceback object at 0x000001564D162700>)
2、可以使用except:或者except Exception,因為在Python中所有的異常都是Exception異常的子類。如下:
try: 1/0 except Exception: print('出錯啦~')
輸出:
出錯啦~
3、可以使用as關(guān)鍵字獲取到出錯的原因,如下:
try: 1/0 except Exception as err: print(f'出錯啦~,出錯原因:{err}')
輸出:
出錯啦~,出錯原因:division by zero
with 語句用于包裝帶有使用上下文管理器定義的方法的代碼塊的執(zhí)行。這允許對普通的 try...except...finally 使用模式進行封裝以方便地重用。
match語句是Python3.10版本中新增的功能。
在條件分支中,如果可能情況不多,可以使用if語句來實現(xiàn)。如果可能的情況比較多,則需要在if語句中使用多個elif子句來實現(xiàn)。從Python3.10版本以后就可以開始使用match語句來實現(xiàn)了。
match語句的基本語法格式如下:
match 變量/表達式:
case 值1 [約束項1]:
子句體1
case 值2 [約束項2]:
子句體2
...
[case :
*子句體*] # 最多有一個,且必須是最后一個子句
1、match語句會對變量或者表達式進行求值,然后與case中的值匹配,如果匹配成功則執(zhí)行相應case子句體,剩下所有的case子句則全部跳過不執(zhí)行。如果全部匹配不成功,則最后可選的case _會被執(zhí)行。
2、語法中的約束項采用的形式為if 表達式,只有case子句匹配成功,并且后面的約束項中的表達式也為真時,才執(zhí)行相應的case子句體。
3、case _是一個必定匹配的case塊,意味著能夠匹配所有情況。match語句中最多可以有一個必定匹配的case塊,而且必須是最后一個。
關(guān)于“Python中復合語句怎么使用”這篇文章的內(nèi)容就介紹到這里,感謝各位的閱讀!相信大家對“Python中復合語句怎么使用”知識都有一定的了解,大家如果還想學習更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道。
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。