国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

[原] Python 開發(fā)者面向文檔編程的正確姿勢(shì)

Y3G / 646人閱讀

摘要:用注釋寫單元測試單元測試是代碼開發(fā)環(huán)節(jié)必不可少的一環(huán),對(duì)于定位和代碼質(zhì)量而言是非常重要的。現(xiàn)在最廣為人知的單元測試框架就是,它借鑒了中成熟的單元測試框架的。

概述

秦人不暇自哀,而后人哀之;后人哀之而不鑒之,亦使后人而復(fù)哀后人也! --論面向文檔編程的重要性

如果想看見識(shí)一個(gè)人寫代碼的功力,注釋其實(shí)是區(qū)分老司機(jī)和小鮮肉的一個(gè)顯著的分界線(有沒有觀察到你們公司的領(lǐng)導(dǎo)基本都在開會(huì)或者寫文檔),通常情況下老司機(jī)的文檔量與代碼量是1:1的比例,而新人往往認(rèn)為寫完功能模塊就已經(jīng)可以完成任務(wù)了。生產(chǎn)環(huán)境中需要面對(duì)現(xiàn)實(shí)中大量復(fù)雜的業(yè)務(wù)邏輯和數(shù)據(jù)校驗(yàn)并與各方對(duì)接,文檔質(zhì)量和代碼質(zhì)量就被提升到了相同的高度。很多人沒有寫注釋的習(xí)慣,大多數(shù)不是因?yàn)閼卸瑁环矫媸菦]有意識(shí)到寫文檔的好處,另一方面是不了解這方面的工具。畢竟從管理上依賴于人的主動(dòng)性是遠(yuǎn)不如依賴于工具有效的。本文介紹如何利用Python注釋提升文檔書寫的質(zhì)量以及效率的小技巧。

Python

在實(shí)際生產(chǎn)中,機(jī)器學(xué)習(xí)工作現(xiàn)在看起來,白天像是個(gè)算法工程師的活,晚上就變成運(yùn)維+測試了。Python 一直以來也都受到測試工程師和運(yùn)維工程師的偏愛,下面是幾個(gè)經(jīng)典的注釋活用case。

用注釋寫單元測試:doctest

單元測試是代碼開發(fā)環(huán)節(jié)必不可少的一環(huán),對(duì)于Bug定位和代碼質(zhì)量而言是非常重要的。現(xiàn)在最廣為人知的單元測試框架就是Unittest,它借鑒了Java中成熟的單元測試框架的JUnit。即使像Django還對(duì)這個(gè)框架有特殊的支持,然而在實(shí)現(xiàn)Unittest的時(shí)候會(huì)感覺確實(shí)比較啰嗦,setup,teardown...在維護(hù)單元測試的時(shí)候很多時(shí)候感覺力不從心。

一個(gè)巧妙的方式可以是通過doctest,用docstring注釋的方式來完成單元測試,由于每個(gè)方法def下面都先跟著一段測試用例,然后緊跟著就是代碼正文,這樣一來很方便我們測試現(xiàn)有代碼的質(zhì)量,另一方面又便于修改。

舉個(gè)例子:

def factorial(n):
    """Return the factorial of n, an exact integer >= 0.

    >>> [factorial(n) for n in range(6)]
    [1, 1, 2, 6, 24, 120]
    >>> factorial(30)
    265252859812191058636308480000000
    >>> factorial(-1)
    Traceback (most recent call last):
        ...
    ValueError: n must be >= 0

    Factorials of floats are OK, but the float must be an exact integer:
    >>> factorial(30.1)
    Traceback (most recent call last):
        ...
    ValueError: n must be exact integer
    >>> factorial(30.0)
    265252859812191058636308480000000

    It must also not be ridiculously large:
    >>> factorial(1e100)
    Traceback (most recent call last):
        ...
    OverflowError: n too large
    """

    import math
    if not n >= 0:
        raise ValueError("n must be >= 0")
    if math.floor(n) != n:
        raise ValueError("n must be exact integer")
    if n+1 == n:  # catch a value like 1e300
        raise OverflowError("n too large")
    result = 1
    factor = 2
    while factor <= n:
        result *= factor
        factor += 1
    return result


if __name__ == "__main__":
    import doctest
    doctest.testmod()

上面是官網(wǎng)提供的一個(gè)求N的階乘函數(shù)示例,在docstring 中通過 >>>符號(hào)來開始一個(gè)單元測試,之后換行輸入預(yù)期結(jié)果即可。實(shí)際上就是復(fù)制粘貼一下調(diào)試過程和結(jié)果,真的再簡單不過了,想實(shí)現(xiàn)TDD也因此變得非常輕松。

用注釋寫API文檔:apidoc

在我們完成機(jī)器學(xué)習(xí)模型后,想要提供一個(gè)對(duì)外服務(wù)的接口以貢獻(xiàn)我們的算力時(shí)就需要完備的API文檔,也是通過API的調(diào)用才能為我們的模型提供源源不斷的校驗(yàn)數(shù)據(jù),對(duì)于提升模型效果有非常實(shí)際的意義。對(duì)大多數(shù)人而言調(diào)用API來完成開發(fā)都是一件比較開心的事情,因?yàn)槲覀兛梢陨僮龊芏喙ぷ骶涂梢詫?shí)現(xiàn)強(qiáng)大功能。然而,當(dāng)我們需要對(duì)外提供API時(shí)就要面臨不一樣的考驗(yàn)了,接口鑒權(quán)、接口設(shè)計(jì)、版本控制、并發(fā)問題、日志埋點(diǎn)...這些都是需要面對(duì)的新問題,而利用 apidoc 可以很好地解決這些API文檔中常見的諸多問題,相當(dāng)于通過模板提升了我們的接口設(shè)計(jì)的能力。

apidoc為Python提供了一種類似于 docstring 的方式來寫API文檔,從語法上看比較類似于 R中的roxygen,都需要用戶以 @xxx 符號(hào)作為一個(gè)開頭,隨后書寫相關(guān)的定義和功能。

舉個(gè)例子:

下面是一個(gè)API接口的定義方法,最核心的部分就是

路由

GET/POST方法

名稱/分組

參數(shù)與調(diào)用例子

(這年頭沒有用例的代碼都是耍流氓)

"""
@api {get} /user/:id Request User information
@apiName GetUser
@apiGroup User

@apiParam {Number} id Users unique ID.

@apiSuccess {String} firstname Firstname of the User.
@apiSuccess {String} lastname  Lastname of the User.
"""

我們可以直接擼一個(gè)官方示例來學(xué)習(xí)如何使用apidoc。

首先,下載示例源碼

git clone https://github.com/apidoc/apidoc
cd apidoc

然后,安裝 apidoc 組件

sudo npm install apidoc -g

接著,利用官方代碼來制作一個(gè)例子,并且訪問即可。

apidoc -i example/ -o output/ -t template/
open output/index.html

幾個(gè)參數(shù)的含義如下:
-i:input,表示輸入的文件夾
-o:output,表示輸出文件夾
-t:template,表示模板文件,通過替換模板我們可以修改文檔皮膚

在 example 文件夾下,我們需要在apidoc.json 中填寫配置文件,定義文檔的header和footer部分內(nèi)容,其余的文件會(huì)被自動(dòng)識(shí)別出其中的docstring作為API文檔的一部分。

由于apidoc的官方文檔非常簡單清晰,所以這里不過多強(qiáng)調(diào)語法。

apidoc 還為我們提供了接口調(diào)試的功能,在實(shí)際使用的時(shí)候要注意:

我們需要一個(gè)web server 才可以使用這個(gè)接口調(diào)試的功能

要注意跨域的問題。

通過版本對(duì)比,我們還可以快速排查API接口的變化情況。需要注意的是這個(gè)功能要求我們要將歷史的文檔記錄也要保存在該目錄下的文件中,通常我們可以把歷史的注釋輸出到一個(gè)特定文件中保存。

總的來說,雖然,API文檔的書寫并不是一件難度非常高的事情,卻能體現(xiàn)系統(tǒng)模塊設(shè)計(jì)和用戶體驗(yàn)設(shè)計(jì)的功力,我們應(yīng)該對(duì)那些無代碼示例,無版本控制的API文檔say no!

用注釋寫命令行接口docopt

利用docopt,我們可以在注釋中直接聲明文件的命令行傳入?yún)?shù),而不需要通過 argvs變量來捕獲輸入值再做判斷,這在調(diào)用運(yùn)維腳本或者若干任務(wù)調(diào)度腳本的時(shí)候尤其管用,極大地提升了CLI的效率。

舉個(gè)例子:(此處代碼僅供參考)

"""Usage:
  fiannceR.py tcp   [--timeout=]
  fiannceR.py serial  [--baud=9600] [--timeout=]
  fiannceR.py -h | --help | --version

"""
from docopt import docopt

if __name__ == "__main__":
    arguments = docopt(__doc__, version="0.1.1rc")
    print(arguments)

隨后,我們可以在命令行中成功調(diào)用

fiannceR.py tcp 0.0.0.0 3838

這里的 arguments 將傳出一個(gè)字典對(duì)象,以Key-Value的形式將命令行中的輸入值捕獲。

{"--baud": None,
 "--help": False,
 "--timeout": None,
 "--version": False,
 "-h": False,
 "": "0.0.0.0",
 "": "3838",
 "serial": False,
 "tcp": True}
總結(jié)

如果真的要從數(shù)據(jù)擼到模型、接口,那么一排注釋的畫面真是美得不敢想象。

"""unitest
>>> FinanceR("20161001")
21.01
"""
def FinanceR(date):
    price = get_price(date)
    return(price)

class(BaseHandler):
    def get(self):   
        """apidoc
           @api {get} /price/:date 獲取當(dāng)前價(jià)格
           @apiName GetPrice
           @apiGroup Quota

           @apiParam {Number} date 交易日期

           @apiSuccess {String} price
        """
        date = self.get_argument("date",None)
        try:
            price = FinanceR(date)
            self.write({"data":{"price":price},"response":{"message":"success","code":200}})
        except Exception as e:
            self.write({"data":None,"response":{"message":str(e),"code":404}})
            
"""Usage:
  fiannceR.py tcp   [--timeout=]
  fiannceR.py serial  [--baud=9600] [--timeout=]
  fiannceR.py -h | --help | --version

"""
from docopt import docopt

if __name__ == "__main__":
    arguments = docopt(__doc__, version="0.1.1rc")
    print(arguments)

歡迎大家留言討論,給出更多應(yīng)用案例,交流分享。

參考文獻(xiàn)

APIDoc

Python 指南:測試你的代碼

doctest

nose is nicer testing for python

tox: standardize testing in Python

Biopython測試框架

Docopt

Sphinx

docopt.R

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/38195.html

相關(guān)文章

  • python入門正確姿勢(shì),從一無所知到無所不知

    摘要:不同的人的路線圖版本會(huì)有所不同。尋找答案從一無所知到無所不知如果你在這個(gè)過程中多次遇到困難,在知難而退之前努力嘗試解決問題。并不是成為一個(gè)全面的開發(fā)人員所需要的唯一技能。首先進(jìn)行一兩個(gè)月的學(xué)習(xí)階段,然后進(jìn)入一個(gè)月的構(gòu)建階段。 初級(jí)開發(fā)者學(xué)Python容易陷入茫然,面對(duì)市面上種類眾多的編程語言和框架,重要的是堅(jiān)持自己的選擇,宜精不宜雜。本文是一篇指路文,概述了從編程基礎(chǔ)、引導(dǎo)、文檔閱讀、...

    legendmohe 評(píng)論0 收藏0
  • python入門正確姿勢(shì),要永遠(yuǎn)做個(gè)學(xué)習(xí)者,但不僅僅只做學(xué)習(xí)者!

    摘要:總之,要永遠(yuǎn)做個(gè)學(xué)習(xí)者,但不僅僅只做學(xué)習(xí)者了解并踐行學(xué)習(xí)實(shí)踐階段循環(huán)任何創(chuàng)造性學(xué)科的學(xué)習(xí)都可以分兩個(gè)階段,學(xué)習(xí)階段和構(gòu)建階段,彼此不斷重復(fù)。 初級(jí)開發(fā)者學(xué)Python容易陷入茫然,面對(duì)市面上種類眾多的編程語言和框架,重要的是堅(jiān)持自己的選擇,宜精不宜雜。本文是一篇指路文,概述了從編程基礎(chǔ)、引導(dǎo)、文檔閱讀、書籍和視頻、源代碼等學(xué)習(xí)和積累環(huán)節(jié),值得初學(xué)者參考。 作為一個(gè)開發(fā)者,為何要選擇Py...

    MarvinZhang 評(píng)論0 收藏0
  • 如何成為一名優(yōu)秀程序員

    摘要:前言羅子雄如何成為一名優(yōu)秀設(shè)計(jì)師董明偉工程師的入門和進(jìn)階董明偉基于自己實(shí)踐講的知乎為新人提供了很多實(shí)用建議,他推薦的羅子雄如何成為一名優(yōu)秀設(shè)計(jì)師的演講講的非常好,總結(jié)了設(shè)計(jì)師從入門到提高的優(yōu)秀實(shí)踐。 前言 羅子雄:如何成為一名優(yōu)秀設(shè)計(jì)師 董明偉:Python 工程師的入門和進(jìn)階 董明偉基于自己實(shí)踐講的知乎live為Python新人提供了很多實(shí)用建議,他推薦的羅子雄:如何成為一名優(yōu)秀...

    keelii 評(píng)論0 收藏0
  • 干貨 | 學(xué)習(xí)Python正確姿勢(shì)

    摘要:勤學(xué)學(xué)習(xí)效率與效果取決于執(zhí)行力。這一步學(xué)習(xí)的正確姿勢(shì)是在實(shí)踐操作中發(fā)掘問題,然后帶著問題找答案。拆分任務(wù)將目標(biāo)分解成具體可執(zhí)行的學(xué)習(xí)任務(wù)。勤學(xué)強(qiáng)大的執(zhí)行力是學(xué)習(xí)的根本保障。分享復(fù)述檢驗(yàn)學(xué)習(xí)成果,提高學(xué)習(xí)效果的最好方法。 showImg(https://segmentfault.com/img/bVbcPGZ?w=256&h=256); 前段時(shí)間和大家一起分享了一篇關(guān)于學(xué)習(xí)方法內(nèi)容《大牛...

    Thanatos 評(píng)論0 收藏0
  • [] Python 發(fā)者如何正確使用 RStudio 編輯器

    摘要:工程師也用過快速開發(fā)面向消費(fèi)者的網(wǎng)站以響應(yīng)一日三變的用戶需求。硬件工程師在樹莓派上用來調(diào)試一個(gè)人臉檢測的功能,以較低的成本完成核心功能的調(diào)試。另一方面,通過在任何一個(gè)瀏覽器中就可以直接前往服務(wù)器現(xiàn)場,不論是一臺(tái)甚至是樹莓派。 概述 資深Python工程師可以選擇的編輯器有很多,比如 Rodeo,Spider,Eclipse,Vim,Visual Studio,Atom,Sublime ...

    el09xccxy 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<