Python學習day09 - Python進階(3)異常處理1. 什麼是異常2. 語法錯誤3. 邏輯錯誤4. 萬能捕捉異常的方式Python深淺拷貝1. 拷貝(賦值)2. 淺拷貝3. 深拷貝基本的文件操做1. 找到文件路徑2. 雙擊打開3. 看文件4. 寫文件5. 關閉文件實戰之猜年齡遊戲html
異常其實就是咱們平時寫程序運行程序時的報錯,在Python中,異常通常分爲兩類,即語法錯誤和邏輯錯誤node
語法錯誤過不了python解釋器的語法檢測,因此在程序執行以前必須改正,不然程序沒法正常執行。python
常見以下例:git
xxxxxxxxxx
if#SyntaxError: invalid syntax
0 = 1#SyntaxError: can't assign to literal
語法錯誤的錯誤類型基本都是SyntaxError
,後面是較詳細的描述。web
邏輯錯誤不一樣於語法錯誤的是,其錯誤類型比較多樣。好比:windows
xxxxxxxxxx
# TypeError:int類型不可迭代
for i in 3:
pass
# ValueError
num=input(">>: ") #輸入hello
int(num)
# NameError
aaa
# IndexError
l=['egon','aa']
l[3]
# KeyError
dic={'name':'egon'}
dic['age']
# AttributeError
class Foo:pass
Foo.x
# ZeroDivisionError:沒法完成計算
res1=1/0
res2=1+'str'
固然咱們捕捉異常是爲了發現,並處理異常,因此這裏介紹一種萬能的捕獲異常的方法:app
xxxxxxxxxx
s1 = 'hello'
try:
int(s1)
except Exception as e:
print(e)
Exception
能夠替代全部的異常類型用來賦值輸出,很是方便。而實際上如今的解釋器自己的報錯,定位錯誤的功能都挺強大的,因此用這個功能比較有限。less
通常Python的拷貝分爲如下三種,咱們分別介紹,用copy以前記得加上頭文件import copy
.dom
賦值的常見方式以下:ide
xxxxxxxxxx
lt = [1, 2, 3]
lt2 = lt
print(lt)
print(lt2)
lt.append(4)
print(lt)
print(lt2)
[1,2,3]
[1,2,3]
[1,2,3,4]
[1,2,3,4]
xxxxxxxxxx
上述打印結果能夠看到,lt的值變化,lt2的值也會跟着變化,這就是最通常的賦值
xxxxxxxxxx
# lt2沒有變化的狀況
lt = [1, 2, 3]
lt2 = copy.copy(lt)
lt.append(4)
print(lt) # [1, 2, 3, 4]
print(lt2) # [1, 2, 3]
以上就是lt2沒有跟隨lt變化而變化,由於添加修改的是一個字符串,不是可變類型。
xxxxxxxxxx
# lt2變化的狀況
lt = [1, 2, 3,[4,5,6]]
lt2 = copy.copy(lt)
lt[3].append(7)
print(lt) # [1, 2, 3, [4,5,6,7]]
print(lt2) # [1, 2, 3,[4,5,6]]
該例就是lt2跟隨lt變化的狀況,由於往裏面添加的是修改一個列表,是可變的類型。
深拷貝是最穩定的拷貝,也是對原值保留最好的,永遠不會隨原值改變。
xxxxxxxxxx
t = [1000, 2000, 3000, [4000, 5000, 6000]]
print('id(lt)',id(lt))
print('id(lt[0])', id(lt[0]))
print('id(lt[1])', id(lt[1]))
print('id(lt[2])', id(lt[2]))
print('id(lt[3])', id(lt[3]))
print('*' * 50)
lt2 = copy.deepcopy(lt)
print('id(lt2)',id(lt2))
print('id(lt2[0])', id(lt2[0]))
print('id(lt2[1])', id(lt2[1]))
print('id(lt2[2])', id(lt2[2]))
print('id(lt2[3])', id(lt2[3]))
print('*' * 50)
由以上打印結果能夠看出,無論lt怎麼改變,lt2都不會隨之改變。
xxxxxxxxxx
# 牢記: 拷貝/淺拷貝/深拷貝 只針對可變數據類型
# 拷貝: 當lt2爲lt的拷貝對象時,lt內的可變類型變化,lt2變化;lt內的不可變類型變化,lt2變化。
#淺拷貝:當lt2爲lt的淺拷貝對象時,lt內的可變類型變化,lt2變化;lt內的不可變類型變化,lt2不變化
# 深拷貝: 當lt2爲lt的深拷貝對象時,lt內的可變類型變化,lt2不變化;lt內的不可變類型變化,lt2不變
什麼是文件呢,以前的博客中有介紹,文件其實就是操做系統提供給用戶的一個虛擬單位,是用來存儲數據的。那麼用Python來對文件操做有如下幾個經常使用的操做。
xxxxxxxxxx
path = r'D:\Python學習\.idea\Python學習.iml'
# python裏就是這樣打開文件路徑的,以上這種也叫作絕對路徑。相對路徑能夠以下表示
path = r'Python學習.iml'
#相對路徑即你所執行的這個py文件的當前文件夾,會默認在這裏搜索
xxxxxxxxxx
f = open(path,'w',encoding = 'utf8')
print(f)
# r-->只讀,w-->只寫,清空當前文件後寫入,後面的encoding爲所打開文件的編碼格式
xxxxxxxxxx
data = f.read()
print(data)
xxxxxxxxxx
f.write('fsfda')
xxxxxxxxxx
del f
f.close()
#須要注意的是,del f只是刪除了解釋器對文件的引用,並無真正關閉文件,只有f.close纔是真正的關閉文件
這是最近學習遇到的第一個稍有規模的代碼,實現方式有不少種,如下兩種僅供參考:
題目需求以下:
常規猜年齡
xxxxxxxxxx
import random
age = random.randint(18, 60) # 隨機一個數字,18-60歲
count = 0 # 計數
f = open('price.txt', 'r', encoding='utf8') # price.txt右下角爲何編碼,則encoding爲何編碼
price_dict = f.read()
price_dict = eval(price_dict) # type:dict # 獲取獎品字典
f.close()
price_self = dict()
while count < 3:
count += 1
inp_age = input('請輸入你想要猜的年齡:')
# 判斷是否爲純數字
if not inp_age.isdigit():
print('搞事就罵你傻逼')
continue
inp_age = int(inp_age)
# 篩選年齡範圍
if inp_age > 60 or inp_age < 18:
print('好好題目,18-60歲,非誠勿擾')
continue
# 核心邏輯
if age == inp_age:
print('猜中了,請選擇你的獎品')
# 打印商品
for k, v in price_dict.items():
print(f'獎品編號:{k} {v}')
# 獲取獎品的兩次循環
for i in range(2):
price_choice = input('請輸入你須要的獎品編號:')
if not price_choice.isdigit():
print("恭喜你已經得到一次獎品,獎品爲空!而且請輸入正確的獎品編號!")
continue
price_choice = int(price_choice)
if price_choice not in price_dict:
print('你想多了吧!')
else:
price_get = price_dict[price_choice]
print(f'恭喜中獎:{price_get}')
if price_self.get(price_get):
price_self[price_get] += 1
else:
price_self[price_get] = 1
print(f'恭喜你得到如下獎品:{price_self}')
break
elif age > inp_age:
print('猜小了')
elif age < inp_age:
print('猜大了')
continue
抽獎式猜年齡
xxxxxxxxxx
import random
age = random.randint(18, 19) # 隨機一個數字,18-60歲
count = 0 # 計數
f = open('price.txt', 'r', encoding='utf8') # price.txt右下角爲何編碼,則encoding爲何編碼
price_dict = f.read()
price_dict = eval(price_dict) # type:dict # 獲取獎品字典
f.close()
price_self = dict()
while count < 3:
count += 1
inp_age = input('請輸入你想要猜的年齡:')
# 判斷是否爲純數字
if not inp_age.isdigit():
print('搞事就罵你傻逼')
continue
inp_age = int(inp_age)
# 篩選年齡範圍
if inp_age > 60 or inp_age < 18:
print('好好題目,18-60歲,非誠勿擾')
continue
# 核心邏輯
if age == inp_age:
print('猜中了,請選擇你的獎品')
# 打印商品
for k, v in price_dict.items():
print(f'獎品編號:{k} {v}')
# 獲取獎品的兩次循環
for i in range(2):
price_y = input(f'請按"Y or y"轉動轉盤{chr(9803)}:').lower()
if price_y != 'y':
print("恭喜你已經得到一次獎品,獎品爲空!而且請輸入'Y or y'!")
continue
#
price_choice = random.randint(0, 10000)
if price_choice > 0 and price_choice < 9900:
price_choice = 6
print('恭喜你, 下次必定有好東西!!', end=' ')
else:
price_choice = price_choice % 7
if price_choice not in price_dict:
print('你想多了吧!')
else:
price_get = price_dict[price_choice]
print(f'恭喜中獎:{price_get}')
if price_self.get(price_get):
price_self[price_get] += 1
else:
price_self[price_get] = 1
print(f'恭喜你得到如下獎品:{price_self}')
break
elif age > inp_age:
print('猜小了')
elif age < inp_age:
print('猜大了')
continue
以上內容均借鑑於恩師nick的博客,但願你們都去借鑑,關注,點贊~