中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久

python程序員開發中常犯的10個錯誤
來源:易賢網 閱讀:1724 次 日期:2016-06-30 09:34:57
溫馨提示:易賢網小編為您整理了“python程序員開發中常犯的10個錯誤”,方便廣大網友查閱!

python是一門簡單易學的編程語言,語法簡潔而清晰,并且擁有豐富和強大的類庫。與其它大多數程序設計語言使用大括號不一樣 ,它使用縮進來定義語句塊。

在平時的工作中,python開發者很容易犯一些小錯誤,這些錯誤都很容易避免,本文總結了python開發者最常犯的10個錯誤,一起來看下,不知你中槍了沒有。

1.濫用表達式作為函數參數默認值

python允許開發者指定一個默認值給函數參數,雖然這是該語言的一個特征,但當參數可變時,很容易導致混亂,例如,下面這段函數定義:

代碼如下:

>>> def foo(bar=[]):        # bar is optional and defaults to [] if not specified

...    bar.append(baz)    # but this line could be problematic, as we'll see...

...    return bar

在上面這段代碼里,一旦重復調用foo()函數(沒有指定一個bar參數),那么將一直返回'bar',因為沒有指定參數,那么foo()每次被調用的時候,都會賦予[]。下面來看看,這樣做的結果:

代碼如下:

>>> foo()

[baz]

>>> foo()

[baz, baz]

>>> foo()

[baz, baz, baz]

解決方案:

代碼如下:

>>> def foo(bar=none):

...    if bar is none:  # or if not bar:

...        bar = []

...    bar.append(baz)

...    return bar

...

>>> foo()

[baz]

>>> foo()

[baz]

>>> foo()

[baz]

2.錯誤地使用類變量

先看下面這個例子:

代碼如下:

>>> class a(object):

...     x = 1

...

>>> class b(a):

...     pass

...

>>> class c(a):

...     pass

...

>>> print a.x, b.x, c.x

1 1 1

這樣是有意義的:

代碼如下:

>>> b.x = 2

>>> print a.x, b.x, c.x

1 2 1

再來一遍:

代碼如下:

>>> a.x = 3

>>> print a.x, b.x, c.x

3 2 3

僅僅是改變了a.x,為什么c.x也跟著改變了。

在python中,類變量都是作為字典進行內部處理的,并且遵循方法解析順序(mro)。在上面這段代碼中,因為屬性x沒有在類c中發現,它會查找它的基類(在上面例子中只有a,盡管python支持多繼承)。換句話說,就是c自己沒有x屬性,獨立于a,因此,引用 c.x其實就是引用a.x。

3.為異常指定不正確的參數

假設代碼中有如下代碼:

代碼如下:

>>> try:

...     l = [a, b]

...     int(l[2])

... except valueerror, indexerror:  # to catch both exceptions, right?

...     pass

...

traceback (most recent call last):

  file <stdin>, line 3, in <module>

indexerror: list index out of range

問題在這里,except語句并不需要這種方式來指定異常列表。然而,在python 2.x中,except exception,e通常是用來綁定異常里的 第二參數,好讓其進行更進一步的檢查。因此,在上面這段代碼里,indexerror異常并沒有被except語句捕獲,異常最后被綁定 到了一個名叫indexerror的參數上。

在一個異常語句里捕獲多個異常的正確方法是指定第一個參數作為一個元組,該元組包含所有被捕獲的異常。與此同時,使用as關鍵字來保證最大的可移植性,python 2和python 3都支持該語法。

代碼如下:

>>> try:

...     l = [a, b]

...     int(l[2])

... except (valueerror, indexerror) as e: 

...     pass

...

>>>

4.誤解python規則范圍

python的作用域解析是基于legb規則,分別是local、enclosing、global、built-in。實際上,這種解析方法也有一些玄機,看下面這個例子:

代碼如下:

>>> x = 10

>>> def foo():

...     x += 1

...     print x

...

>>> foo()

traceback (most recent call last):

  file <stdin>, line 1, in <module>

  file <stdin>, line 2, in foo

unboundlocalerror: local variable 'x' referenced before assignment

許多人會感動驚訝,當他們在工作的函數體里添加一個參數語句,會在先前工作的代碼里報unboundlocalerror錯誤( 點擊這里查看更詳細描述)。

在使用列表時,開發者是很容易犯這種錯誤的,看看下面這個例子:

代碼如下:

>>> lst = [1, 2, 3]

>>> def foo1():

...     lst.append(5)   # this works ok...

...

>>> foo1()

>>> lst

[1, 2, 3, 5]

>>> lst = [1, 2, 3]

>>> def foo2():

...     lst += [5]      # ... but this bombs!

...

>>> foo2()

traceback (most recent call last):

  file <stdin>, line 1, in <module>

  file <stdin>, line 2, in foo

unboundlocalerror: local variable 'lst' referenced before assignment

為什么foo2失敗而foo1運行正常?

答案與前面那個例子是一樣的,但又有一些微妙之處。foo1沒有賦值給lst,而foo2賦值了。lst += [5]實際上就是lst = lst + [5],試圖給lst賦值(因此,假設python是在局部作用域里)。然而,我們正在尋找指定給lst的值是基于lst本身,其實尚未確定。

5.修改遍歷列表

下面這段代碼很明顯是錯誤的:

代碼如下:

>>> odd = lambda x : bool(x % 2)

>>> numbers = [n for n in range(10)]

>>> for i in range(len(numbers)):

...     if odd(numbers[i]):

...         del numbers[i]  # bad: deleting item from a list while iterating over it

...

traceback (most recent call last):

     file <stdin>, line 2, in <module>

indexerror: list index out of range

在遍歷的時候,對列表進行刪除操作,這是很低級的錯誤。稍微有點經驗的人都不會犯。

對上面的代碼進行修改,正確地執行:

代碼如下:

>>> odd = lambda x : bool(x % 2)

>>> numbers = [n for n in range(10)]

>>> numbers[:] = [n for n in numbers if not odd(n)]  # ahh, the beauty of it all

>>> numbers

[0, 2, 4, 6, 8]

6.如何在閉包中綁定變量

看下面這個例子:

代碼如下:

>>> def create_multipliers():

...     return [lambda x : i * x for i in range(5)]

>>> for multiplier in create_multipliers():

...     print multiplier(2)

...

你期望的結果是:

代碼如下:

0

2

4

6

8

實際上:

代碼如下:

8

8

8

8

8

是不是非常吃驚!出現這種情況主要是因為python的后期綁定行為,該變量在閉包中使用的同時,內部函數又在調用它。

解決方案:

代碼如下:

>>> def create_multipliers():

...     return [lambda x, i=i : i * x for i in range(5)]

...

>>> for multiplier in create_multipliers():

...     print multiplier(2)

...

0

2

4

6

8

7.創建循環模塊依賴關系

假設有兩個文件,a.py和b.py,然后各自導入,如下:

在a.py中:

代碼如下:

import b

def f():

    return b.x

print f()

在b.py中:

代碼如下:

import a

x = 1

def g():

    print a.f()

首先,讓我們試著導入a.py:

代碼如下:>>> import a

1

可以很好地工作,也許你會感到驚訝。畢竟,我們確實在這里做了一個循環導入,難道不應該有點問題嗎?

僅僅存在一個循環導入并不是python本身問題,如果一個模塊被導入,python就不會試圖重新導入。根據這一點,每個模塊在試圖訪問函數或變量時,可能會在運行時遇到些問題。

當我們試圖導入b.py會發生什么(先前沒有導入a.py):

代碼如下:

>>> import b

traceback (most recent call last):

     file <stdin>, line 1, in <module>

     file b.py, line 1, in <module>

    import a

     file a.py, line 6, in <module>

 print f()

     file a.py, line 4, in f

 return b.x

attributeerror: 'module' object has no attribute 'x'

出錯了,這里的問題是,在導入b.py的過程中還要試圖導入a.py,這樣就要調用f(),并且試圖訪問b.x。但是b.x并未被定義。

可以這樣解決,僅僅修改b.py導入到a.py中的g()函數:

代碼如下:

x = 1

def g():

    import a # this will be evaluated only when g() is called

    print a.f()

無論何時導入,一切都可以正常運行:

代碼如下:

>>> import b

>>> b.g()

1 # printed a first time since module 'a' calls 'print f()' at the end

1 # printed a second time, this one is our call to 'g'

8.與python標準庫模塊名稱沖突

python擁有非常豐富的模塊庫,并且支持“開箱即用”。因此,如果不刻意避免,很容易發生命名沖突事件。例如,在你的代碼中可能有一個email.py的模塊,由于名稱一致,它很有可能與python自帶的標準庫模塊發生沖突。

9.未按規定處理python2.x和python3.x之間的區別

看一下foo.py:

代碼如下:

import sys

def bar(i):

    if i == 1:

        raise keyerror(1)

    if i == 2:

        raise valueerror(2)

def bad():

    e = none

    try:

        bar(int(sys.argv[1]))

    except keyerror as e:

        print('key error')

    except valueerror as e:

        print('value error')

    print(e)

bad()

在python 2里面可以很好地運行:

代碼如下:

$ python foo.py 1

key error

1

$ python foo.py 2

value error

2

但是在python 3里:

代碼如下:

$ python3 foo.py 1

key error

traceback (most recent call last):

  file foo.py, line 19, in <module>

    bad()

  file foo.py, line 17, in bad

    print(e)

unboundlocalerror: local variable 'e' referenced before assignment

解決方案:

代碼如下:

import sys

def bar(i):

    if i == 1:

        raise keyerror(1)

    if i == 2:

        raise valueerror(2)

def good():

    exception = none

    try:

        bar(int(sys.argv[1]))

    except keyerror as e:

        exception = e

        print('key error')

    except valueerror as e:

        exception = e

        print('value error')

    print(exception)

good()

在py3k中運行結果:

代碼如下:$ python3 foo.py 1

key error

1

$ python3 foo.py 2

value error

2

在 python招聘指南里有許多關于python 2與python 3在移植代碼時需要關注的注意事項與討論,大家可以前往看看。

10.濫用__del__方法

比如這里有一個叫mod.py的文件:

代碼如下:

import foo

class bar(object):

        ...

    def __del__(self):

        foo.cleanup(self.myhandle)

下面,你在another_mod.py文件里執行如下操作:

代碼如下:

import mod

mybar = mod.bar()

你會獲得一個attributeerror異常。

至于為什么會出現該異常,點擊這里查看詳情。當解釋器關閉時,該模塊的全局變量全部設置為none。因此,在上面這個例子里,當__del__被調用時,foo已經全部被設置為none。

一個很好的解決辦法是使用atexit.register()代替。順便說一句,當程序執行完成后,您注冊的處理程序會在解釋器關閉之前停止 工作。

修復上面問題的代碼:

代碼如下:

import foo

import atexit

def cleanup(handle):

    foo.cleanup(handle)

class bar(object):

    def __init__(self):

        ...

        atexit.register(cleanup, self.myhandle)

在程序的正常終止的前提下,這個實現提供了一個整潔可靠的方式調用任何需要清理的功能。

總結:

python是一款強大而靈活的編程語言,并且帶有許多機制和模式來大大提高工作效率。正如任何一門語言或軟件工具一樣,人們對其能力都會存在一個限制性地理解或欣賞,有些是弊大于利,有些時候反而會帶來一些陷進。 體會一名語言的細微之處,理解一些常見的陷阱,有助于你在開發者的道路上走的更遠。

更多信息請查看腳本欄目
易賢網手機網站地址:python程序員開發中常犯的10個錯誤
由于各方面情況的不斷調整與變化,易賢網提供的所有考試信息和咨詢回復僅供參考,敬請考生以權威部門公布的正式信息和咨詢為準!

2026上岸·考公考編培訓報班

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
云南網警備案專用圖標
聯系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網
云南網警報警專用圖標
中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久
久久久久久一区二区| 国产精品你懂的| 国产综合视频| 欧美日韩日韩| 欧美二区在线播放| 久久久精品国产免费观看同学| 99国产精品久久久久老师| 在线电影欧美日韩一区二区私密| 国产伦精品一区二区三| 国产精品家庭影院| 欧美三级电影一区| 欧美大片18| 欧美成人亚洲成人日韩成人| 久热国产精品| 美女久久一区| 欧美成人福利视频| 欧美成人精品高清在线播放| 欧美成人激情视频| 榴莲视频成人在线观看| 久久米奇亚洲| 亚洲视频999| 亚洲天堂成人在线视频| 亚洲校园激情| 欧美中文字幕在线| 久久免费视频在线| 欧美成人免费观看| 欧美日韩福利在线观看| 欧美私人网站| 国产精品专区第二| 一色屋精品视频在线看| 影音先锋久久资源网| 亚洲国产一区视频| 亚洲人成人一区二区三区| 亚洲精品婷婷| 亚洲欧美精品suv| 久久久国产成人精品| 蜜桃久久av一区| 欧美日韩成人一区| 国产精品久久久久三级| 国产亚洲一级| 亚洲激情视频在线| 一区二区三区精品视频| 久久av最新网址| 国产偷国产偷亚洲高清97cao | 欧美激情一区二区三区蜜桃视频| 蜜臀久久99精品久久久久久9 | 黄色成人在线网址| 91久久久在线| 亚洲一区二区三区在线看| 亚洲免费中文| 久久精品亚洲一区| 欧美日韩情趣电影| 国产欧美日韩视频一区二区三区 | 亚洲男女自偷自拍图片另类| 久久久亚洲高清| 在线综合亚洲欧美在线视频| 亚洲国产美女精品久久久久∴| 国产亚洲欧美日韩一区二区| 国产精品久久久久婷婷| 亚洲欧美在线一区| 亚洲一区国产| 亚洲国产精品va在线观看黑人| 欧美日韩精品免费观看| 亚洲欧美日韩国产中文| 亚洲精品影院在线观看| 激情久久一区| 亚洲精选在线观看| 亚洲日本va午夜在线影院| 亚洲成人影音| 亚洲人成在线播放| 日韩视频久久| 亚洲女优在线| 久久在线精品| 欧美日韩国产二区| 欧美日韩在线另类| 国产欧美一区二区视频| 国产综合久久久久久鬼色| 狠狠操狠狠色综合网| 日韩视频不卡| 欧美一区在线看| 久久资源在线| 欧美日韩精品中文字幕| 国产欧美一区二区色老头| 国产一区二区中文| 久久精品青青大伊人av| 亚洲欧美日韩久久精品| 午夜精品久久久久久99热| 久久精品中文| 欧美成人黄色小视频| 国产精品久久久久久久久免费桃花| 国产精品国产三级国产| 国产亚洲精品aa午夜观看| 亚洲精品小视频| 亚洲欧洲日本专区| 中文精品视频一区二区在线观看| 欧美一区二区三区免费大片| 亚洲视频在线观看三级| 久久久久久久久久久久久久一区| 欧美三区免费完整视频在线观看| 国产日韩一区二区| 亚洲乱码视频| 另类av一区二区| 国内精品模特av私拍在线观看| 亚洲靠逼com| 欧美精品一区二区三区蜜桃 | 国产亚洲一区二区三区| 亚洲美女视频| 另类av导航| 亚洲电影观看| 欧美 日韩 国产 一区| 国产区在线观看成人精品| 国产拍揄自揄精品视频麻豆| 亚洲天堂网在线观看| 欧美少妇一区| 亚洲欧美变态国产另类| 国产精品永久免费| 久久国产一区| 亚洲人成精品久久久久| 欧美区日韩区| 香蕉av福利精品导航| 亚洲综合视频一区| 国产乱码精品一区二区三区五月婷| 亚洲一区二区欧美| 欧美日韩日本国产亚洲在线| 一本一本久久a久久精品综合麻豆| 亚洲高清视频在线观看| 午夜久久久久久| 狠狠色丁香久久婷婷综合丁香| 欧美va亚洲va国产综合| 国产精品99久久不卡二区| 国产视频精品va久久久久久| 老司机精品久久| 亚洲欧美亚洲| 亚洲精品国产无天堂网2021| 国产精品久久久久一区二区三区共| 玖玖精品视频| 香蕉久久夜色| 欧美黄色一区| 亚洲一区二区欧美| 极品av少妇一区二区| 国产精品都在这里| 欧美精品二区| 蜜臀久久99精品久久久久久9| 性久久久久久久久久久久| 99精品欧美一区二区蜜桃免费| 黄色成人片子| 国产精品日韩在线一区| 欧美日韩一区二区三| 国产午夜精品美女毛片视频| 欧美日韩在线一二三| 欧美日韩免费精品| 欧美风情在线| 欧美激情视频在线免费观看 欧美视频免费一| 亚洲欧美激情一区| 一区二区欧美日韩| 夜夜夜久久久| 亚洲一区成人| 午夜国产一区| 性欧美办公室18xxxxhd| 欧美制服丝袜第一页| 久久久午夜视频| 欧美激情1区2区3区| 亚洲手机视频| 香蕉久久精品日日躁夜夜躁| 欧美一区二区久久久| 亚洲自拍三区| 久色成人在线| 国产精品啊啊啊| 国产一区导航| 亚洲免费激情| 美女黄网久久| 国产精品夜夜嗨| 亚洲国产日韩欧美在线99| 亚洲一区网站| 免费观看在线综合| 欧美日韩国产色综合一二三四| 国产精品自拍三区| 伊人久久成人| 欧美一区精品| 国产精品视频1区| 亚洲免费观看| 欧美日韩精品免费| 最新成人在线| 蜜桃av一区二区三区| 韩国av一区二区三区| 亚洲免费一在线| 欧美无砖砖区免费| 一本大道av伊人久久综合| 欧美国产视频日韩| 亚洲欧洲另类国产综合| 女人天堂亚洲aⅴ在线观看| 国产有码在线一区二区视频| 欧美亚洲免费在线| 国产日韩欧美一区二区| 亚洲影院色无极综合| 国产精品国产三级国产aⅴ入口| 亚洲乱码精品一二三四区日韩在线| 免费成人在线观看视频| 91久久精品国产91性色tv| 欧美激情在线狂野欧美精品|