python參數(shù)類型錯(cuò)誤是什么-創(chuàng)新互聯(lián)

創(chuàng)新互聯(lián)www.cdcxhl.cn八線動(dòng)態(tài)BGP香港云服務(wù)器提供商,新人活動(dòng)買多久送多久,劃算不套路!

成都創(chuàng)新互聯(lián)公司成立十余年來,這條路我們正越走越好,積累了技術(shù)與客戶資源,形成了良好的口碑。為客戶提供網(wǎng)站制作、網(wǎng)站設(shè)計(jì)、網(wǎng)站策劃、網(wǎng)頁(yè)設(shè)計(jì)、域名與空間、網(wǎng)絡(luò)營(yíng)銷、VI設(shè)計(jì)、網(wǎng)站改版、漏洞修補(bǔ)等服務(wù)。網(wǎng)站是否美觀、功能強(qiáng)大、用戶體驗(yàn)好、性價(jià)比高、打開快等等,這些對(duì)于網(wǎng)站建設(shè)都非常重要,成都創(chuàng)新互聯(lián)公司通過對(duì)建站技術(shù)性的掌握、對(duì)創(chuàng)意設(shè)計(jì)的研究為客戶提供一站式互聯(lián)網(wǎng)解決方案,攜手廣大客戶,共同發(fā)展進(jìn)步。

python參數(shù)類型錯(cuò)誤是什么?相信很多沒有經(jīng)驗(yàn)的人對(duì)此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個(gè)問題。

在Python中,不知道函數(shù)參數(shù)類型是一個(gè)很正常的事情,特別是在一個(gè)大項(xiàng)目里。

我見過有些項(xiàng)目里,每一個(gè)函數(shù)體的前十幾行都在檢查參數(shù)類型,這實(shí)在是太麻煩了。而且一旦參數(shù)有改動(dòng),這部分也需要改動(dòng)。

下面我們用裝飾器來實(shí)現(xiàn),函數(shù)參數(shù)的強(qiáng)制類型檢查。

首先,這個(gè)裝飾器,要接受類型參數(shù),和指定函數(shù)參數(shù)的類型參數(shù)。也就是一個(gè)list和一個(gè)dict

from functools import wrapsdef typeassert(*type_args, **type_kwargs):
    def decorate(func):
        @wraps(func)
        def wrapper(*args, **kwargs):
            return func(*args, **kwargs)
        return wrapper    return decorate

那么,接下來,在裝飾器中,我們需要獲取函數(shù)參數(shù)列表,并且要和類型參數(shù)表映射。
這要借助Python的一個(gè)標(biāo)準(zhǔn)庫(kù)——inspect 這個(gè)庫(kù)一般用于Python代碼調(diào)試

from inspect import signaturefrom functools import wrapsdef typeassert(*type_args, **type_kwargs):
    def decorate(func):
        sig = signature(func)
        bound_types = sig.bind_partial(*type_args, **type_kwargs).arguments

        @wraps(func)
        def wrapper(*args, **kwargs):
            return func(*args, **kwargs)
        return wrapper    return decorate

上面的代碼中,我們使用inspect中的signature方法獲取了func的Signature對(duì)象,然后使用bind_partial方法創(chuàng)建了(*type_args, **type_kwargs)到func參數(shù)的映射(也就是一個(gè)字典)。

接下來就簡(jiǎn)單了,我們只需要再獲取(*args, **kwargs)的類型,使用isintance函數(shù)進(jìn)行比較就好。

from inspect import signaturefrom functools import wrapsdef typeassert(*type_args, **type_kwargs):
    def decorate(func):
        sig = signature(func)
        bound_types = sig.bind_partial(*type_args, **type_kwargs).arguments

        @wraps(func)
        def wrapper(*args, **kwargs):
            bound_values = sig.bind(*args, **kwargs)
            for name, value in bound_values.arguments.items():
                if name in bound_types:
                    if not isinstance(value, bound_types[name]):
                        raise TypeError('Argument {} must be {}'.format(name, bound_types[name]))
            return func(*args, **kwargs)
        return wrapper    return decorate

運(yùn)行如下代碼

@typeassert(int, int)
def add(x, y):
return x+y

print(add("u", 2))

能看到報(bào)錯(cuò)如下

Traceback (most recent call last):
  File "c:\Users\Chen\Desktop\typeassert.py", line 32, in <module>
    print(add("u", 2))
  File "c:\Users\Chen\Desktop\typeassert.py", line 22, in wrapper
    'Argument {} must be {}'.format(name, bound_types[name])
TypeError: Argument x must be <class 'int'>

很貼心的提醒了我們哪一個(gè)參數(shù)應(yīng)該是什么類型。你甚至可以自己改動(dòng)這個(gè)裝飾器,讓它還能告訴你傳進(jìn)去了什么錯(cuò)誤參數(shù)(特別是寫爬蟲的時(shí)候,參數(shù)很難掌握,一旦報(bào)錯(cuò),還得重跑一遍才知道為什么。)

你也可以指定某一個(gè)參數(shù)的類型,譬如

@typeassert(int, z=str)
def display(x, y, z):
    print(x, y, z)

這時(shí)你會(huì)發(fā)現(xiàn),y的類型就像原生的Python函數(shù)一樣,什么都行。而x必須是int,z必須是str。

看完上述內(nèi)容,你們掌握python參數(shù)類型錯(cuò)誤是什么的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)-成都網(wǎng)站建設(shè)公司行業(yè)資訊頻道,感謝各位的閱讀!

網(wǎng)頁(yè)題目:python參數(shù)類型錯(cuò)誤是什么-創(chuàng)新互聯(lián)
瀏覽路徑:http://muchs.cn/article8/dpdhip.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供Google網(wǎng)站營(yíng)銷、動(dòng)態(tài)網(wǎng)站營(yíng)銷型網(wǎng)站建設(shè)網(wǎng)站策劃、云服務(wù)器

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

小程序開發(fā)