溫馨提示×

溫馨提示×

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

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

如何實現(xiàn)Python腳本生成命令行

發(fā)布時間:2022-05-23 09:16:34 來源:億速云 閱讀:213 作者:iii 欄目:開發(fā)技術

這篇文章主要講解了“如何實現(xiàn)Python腳本生成命令行”,文中的講解內(nèi)容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“如何實現(xiàn)Python腳本生成命令行”吧!

    有時候我們會有這樣的一個需求:

    我們定義了一個 Python 的方法,方法接收一些參數(shù),但是調(diào)用的時候想將這些參數(shù)用命令行暴露出來。

    比如說這里有個爬取方法:

    import requests
    def scrape(url, timeout=10):
        response = requests.get(url, timeout=timeout)
        print(response.text)

    這里定義了一個 scrape 方法,第一個參數(shù)接收 url,即爬取的網(wǎng)址,第二個參數(shù)接收 timeout,即指定超時時間。

    調(diào)用的時候我們可能這么調(diào)用:

    scrape('https:///www.baidu.com', 10)

    如果我們想改參數(shù)換 url,那就得改代碼對吧。

    所以有時候我們就想把這些參數(shù)用命令行暴露出來,這時候我們可能就用上了 argparse 等等的庫,挨個聲明各個參數(shù)是干嘛的,非常繁瑣,

    代碼如下:

    parser = argparse.ArgumentParser(description='Scrape Function')
    parser.add_argument('url', type=str,
                        help='an integer for the accumulator')
    parser.add_argument('timeout',  type=int,
                        help='sum the integers (default: find the max)')
    if __name__ == '__main__':
        args = parser.parse_args()
        scrape(args.url, args.timeout)

    這樣我們才能順利地使用命令行來調(diào)用這個腳本:

    python3 main.py https://www.baidu.com 10

    是不是感覺非常麻煩?argparse 寫起來又臭又長,想想就費勁。

    Fire

    但接下來我們要介紹一個庫,用它我們只需要兩行代碼就可以做到如上操作。

    這個庫的名字叫做Fire,它可以快速為某個 Python 方法或者類添加命令行的參數(shù)支持。

    先看看安裝方法,使用 pip3 安裝即可:

    pip3 install fire

    這樣我們就安裝好了。

    使用方法

    下面我們來看幾個例子。

    方法支持

    第一個代碼示例如下:

    import fire
    def hello(name="World"):
      return "Hello %s!" % name
    if __name__ == '__main__':
      fire.Fire(hello)

    這里我們定義了一個 hello 方法,然后接收一個 name 參數(shù),默認值是 World,接著輸出了 Hello 加 name 這個字符串。

    然后接著我們導入了 fire 這個庫,調(diào)用它的 Fire 方法并傳入 hello 這個方法聲明,會發(fā)生什么事情呢?

    我們把這段代碼保存為 demo1.py,接著用 Python3 來運行一下:

    python3 demo1.py

    運行結果如下:

    Hello World!

    看起來并沒有什么不同。

    但我們這時候如果運行如下命令,就可以看到一些神奇的事情了:

    python3 demo1.py --help

    運行結果如下:

    NAME
        demo1.py
    SYNOPSIS
        demo1.py <flags>
    FLAGS
        --name=NAME
            Default: 'World'

    可以看到,這里它將 name 這個參數(shù)轉(zhuǎn)化成了命令行的一個可選參數(shù),我們可以通過 &mdash;-name 來替換 name 參數(shù)。

    我們來試下:

    python3 demo1.py --name 123

    這里我們傳入了一個 name 參數(shù)是 123,這時候我們就發(fā)現(xiàn)運行結果就變成了如下內(nèi)容:

    Hello 123!

    是不是非常方便?我們沒有借助 argparse 就輕松完成了命令行參數(shù)的支持和替換。

    那如果我們將 name 這個參數(shù)的默認值取消呢?代碼改寫如下:

    import fire
    def hello(name):
      return "Hello %s!" % name
    if __name__ == '__main__':
      fire.Fire(hello)

    這時候重新運行:

    python3 demo1.py --help

    就可以看到結果變成了如下內(nèi)容:

    NAME
        demo1.py
    SYNOPSIS
        demo1.py NAME
    POSITIONAL ARGUMENTS
        NAME
    NOTES
        You can also use flags syntax for POSITIONAL ARGUMENTS

    這時候我們發(fā)現(xiàn) name 這個參數(shù)就變成了必傳參數(shù),我們必須在命令行里指定這個參數(shù)內(nèi)容,調(diào)用就會變成如下命令:

    python3 demo1.py 123

    運行結果還是一樣的。

    類支持

    當然 fire 這個庫不僅僅支持給方法添加命令行的支持,還支持給一個類添加命令行的支持。

    下面我們再看一個例子:

    import fire
    class Calculator(object):    
        def double(self, number):
            return 2 * number
    if __name__ == '__main__':
        fire.Fire(Calculator)

    我們把這個代碼保存為 demo2.py,然后運行:

    python3 demo2.py

    運行結果如下:

    NAME
        demo2.py

    SYNOPSIS
        demo2.py COMMAND

    COMMANDS
        COMMAND is one of the following:

         double

    可以看到,這里它將 Calculator 這個類中的方法識別出來了,COMMAND 之一就是 double,我們試著調(diào)用下:

    python3 demo2.py double

    運行結果如下:

    ERROR: The function received no value for the required argument: number
    Usage: demo2.py double NUMBER

    For detailed information on this command, run:
      demo2.py double --help

    這里就說了,這里必須要指定另外一個參數(shù),叫做 NUMBER,同時這個參數(shù)還是必填參數(shù),我們試著加下:

    python3 demo2.py double 4

    運行結果如下:

    8

    這時候就可以達到正確結果了。

    所以說,綜合來看,fire 可以為一個類命令行,每個命令都對應一個方法的名稱,同時在后面添加額外的可選或必選參數(shù),加到命令行參數(shù)的后面。

    重新改寫

    最后,讓我們回過頭來,給我們一開始定義的 scrape 方法添加命令行的參數(shù)支持:

    import requests
    import fire
    def scrape(url, timeout=10):
        response = requests.get(url, timeout=timeout)
        print(response.text)
    if __name__ == '__main__':
        fire.Fire(scrape)

    這樣就可以了!省去了冗長的 argparse 的代碼,是不是非常方便?

    調(diào)用就是如下形式:

    NAME
        main.py
    SYNOPSIS
        main.py URL <flags>
    
    POSITIONAL ARGUMENTS
        URL
    FLAGS
        --timeout=TIMEOUT
            Default: 10

    這里說了,URL 是必傳參數(shù),timeout 是可選參數(shù)。

    最后調(diào)用下:

    python3 main.py https://www.baidu.com

    這樣我們就可以輕松將 url 通過命令行傳遞過去了。

    當然 timeout 還是可選值,我們可以通過 &mdash;-timeout 來指定 timeout 參數(shù):

    python3 main.py https://www.baidu.com --timeout 5

    這樣兩個參數(shù)就都能順利賦值了,最后效果就是爬取百度,5 秒超時。

    感謝各位的閱讀,以上就是“如何實現(xiàn)Python腳本生成命令行”的內(nèi)容了,經(jīng)過本文的學習后,相信大家對如何實現(xiàn)Python腳本生成命令行這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

    向AI問一下細節(jié)

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

    AI