溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

對Python中一些“坑”的總結及技巧

發(fā)布時間:2020-07-06 19:10:13 來源:網絡 閱讀:465 作者:Python熱愛者 欄目:編程語言

一.賦值即定義

1.運行以下代碼會出現報錯

#!/usr/bin/env python
#_*_conding:utf-8_*_
x = 100
def outer():
    def inner():
        x += 100    #其實這里等效于"x = x + 100",我們直到這是一個賦值語句,會優(yōu)先計算右邊的等式,即"x + 100".而在此時由于x變量賦值即定義,即此時的x和全局作用域的x并非同一個對象。
        print(x)
    return inner
foo = outer()
foo()

對Python中一些“坑”的總結及技巧

2.使用global關鍵字解決以上報錯

'''
遇到問題沒人解答?小編創(chuàng)建了一個Python學習交流QQ群:579817333 
尋找有志同道合的小伙伴,互幫互助,群里還有不錯的視頻學習教程和PDF電子書!
'''
#!/usr/bin/env python
#_*_conding:utf-8_*_
x = 100
def outer():
    def inner():
        global x        
  #注意,我們先要在inner作用域中使用全局作用域的同名x變量就得優(yōu)先使用"global"關鍵字進行聲明。
        x += 100
        print(x)
    return inner
foo = outer()
foo()

#以上代碼輸出結果如下:
200

3.不推薦使用global

global總結

x+=1這種是特殊形式產生的錯誤的原因?先引用后賦值,而python動態(tài)語言是賦值才算定義,才能被引用。解決辦法,在這條語句前增加x=0之類的賦值語句,或者使用global告訴內部作用域,去全局作用域查找變量定義
內部作用域使用x = 5之類的賦值語句會重新定義局部作用域使用的變量x,但是,一旦這個作用域中使用global聲明x為全局的,那么x=5相當于在為全局作用域的變量x賦值

global使用原則

外部作用域變量會內部作用域可見,但也不要在這個內部的局部作用域中直接使用,因為函數的目的就是為了封裝,盡量與外界隔離
如果函數需要使用外部全局變量,請使用函數的形參傳參解決
一句話:不用global。學習它就是為了深入理解變量作用域.

二.列表中的"+"與"+="的區(qū)別

1.觀察以下代碼

#!/usr/bin/env python
#_*_conding:utf-8_*_

def demo(x=[]):
    x += [1]                        #就地修改前一個列表,在其后追加后一個列表。就是extend方法。
    print(x)

print(demo.__defaults__)            #我們可以查看默認參數列表

demo()                                                      

demo()

print(demo.__defaults__)            
#發(fā)現demo函數被調用2次后,默認參數的值也在跟隨著變化!其原因是demo()執(zhí)行完后彈棧會消亡,但解釋器始終保留了一份"def demo(x=[])"的函數簽名,這里面的x變量會隨著解釋器的消亡而消亡,除非我們使用"del"關鍵字去現實的刪除該函數!如果我們這樣干的話,后續(xù)就無法訪問到該函數啦!

#以上代碼輸出結果如下:
([],)
[1]
[1, 1]
([1, 1],)#!/usr/bin/env python
#_*_conding:utf-8_*_
#@author :yinzhengjie
#blog:http://www.cnblogs.com/yinzhengjie

def demo(x=[]):
    x += [1]                        #就地修改前一個列表,在其后追加后一個列表。就是extend方法。
    print(x)

print(demo.__defaults__)            #我們可以查看默認參數列表

demo()                                                      

demo()

print(demo.__defaults__)            #發(fā)現demo函數被調用2次后,默認參數的值也在跟隨著變化!其原因是demo()執(zhí)行完后彈棧會消亡,但解釋器始終保留了一份"def demo(x=[])"的函數簽名,這里面的x變量會隨著解釋器的消亡而消亡,除非我們使用"del"關鍵字去現實的刪除該函數!如果我們這樣干的話,后續(xù)就無法訪問到該函數啦!

#以上代碼輸出結果如下:
([],)
[1]
[1, 1]
([1, 1],)

2.列表防坑總結

列表的"+"和"+="的區(qū)別:
"+"表示兩個列表合并并返回一個全新的列表。
"+="表示,就地修改前一個列表,在其后追加一個列表。就是extend方法。

3.注意引用變量的是可以被就地修改的(以函數的默認值參數為例)

'''
遇到問題沒人解答?小編創(chuàng)建了一個Python學習交流QQ群:579817333 
尋找有志同道合的小伙伴,互幫互助,群里還有不錯的視頻學習教程和PDF電子書!
'''
#!/usr/bin/env python
#_*_conding:utf-8_*_

def demo2(x=1,y="abc",z={},*args,m=100,n,**kwargs):
    print(x,y,z)                            #打印位置參數
    print(m,n)                              #打印key-only關鍵詞參數
    print(z.setdefault("abc","mn"))         #我們?yōu)?z"變量設置一組鍵值對

print(demo2.__defaults__,demo2.__kwdefaults__)      
#我們知道"__defaults__"保留的是位置參數相關信息,而"__kwdefaults__"保留的是關鍵字相關信息

demo2(n=200)

demo2(z = {},n = 200)

print(demo2.__defaults__,demo2.__kwdefaults__)      #我們發(fā)現默認的"z"變量值是被咱們有意修改啦~

#以上代碼輸出結果如下:
(1, 'abc', {}) {'m': 100}
1 abc {}
100 200
mn
1 abc {}
100 200
mn
(1, 'abc', {'abc': 'mn'}) {'m': 100}
向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI