欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2022年05月22日 10:38:16   作者:??崔慶才丨靜覓????  
這篇文章主要介紹了實現(xiàn)?Python?腳本生成命令行,文章通過定義一個?scrape?方法展開詳細內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下

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

我們定義了一個 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ù),我們可以通過 —-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 還是可選值,我們可以通過 —-timeout 來指定 timeout 參數(shù):

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

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

到此這篇關于實現(xiàn) Python 腳本生成命令行的文章就介紹到這了,更多相關 Python 命令行內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • python添加列表元素append(),extend()及?insert()

    python添加列表元素append(),extend()及?insert()

    這篇文章主要介紹了python添加列表元素append(),extend()及?insert(),列表是儲存元素的數(shù)據(jù)類型,既然能存儲元素,那么就類似數(shù)據(jù)庫一樣,增刪改查的一些功能就不能少了。下面我們就來先看看添加列表元素方法有哪些,需要的朋友可以參考一下
    2022-03-03
  • python能在瀏覽器能運行嗎

    python能在瀏覽器能運行嗎

    在本篇文章里小編給大家整理了關于python能否在瀏覽器能運行的相關知識點內(nèi)容,有需要的朋友們可以學習下。
    2020-06-06
  • Python基礎之數(shù)據(jù)類型相關知識總結

    Python基礎之數(shù)據(jù)類型相關知識總結

    眾所周知,在Python中,常用的數(shù)據(jù)類型有三種,分別是字符串、整數(shù)和浮點數(shù).在Python基礎學習的過程中,數(shù)據(jù)類型是初學者常常容易混淆的一個基礎知識點,本文為大家詳細總結了三種數(shù)據(jù)類型的概念、數(shù)據(jù)類型的查詢以及更為復雜的數(shù)據(jù)轉(zhuǎn)化,需要的朋友可以參考下
    2021-06-06
  • python hough變換檢測直線的實現(xiàn)方法

    python hough變換檢測直線的實現(xiàn)方法

    這篇文章主要介紹了python hough變換檢測直線的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-07-07
  • Python+OpenCV圖像處理——實現(xiàn)輪廓發(fā)現(xiàn)

    Python+OpenCV圖像處理——實現(xiàn)輪廓發(fā)現(xiàn)

    這篇文章主要介紹了Python+OpenCV實現(xiàn)輪廓發(fā)現(xiàn),幫助大家更好的利用python處理圖片,感興趣的朋友可以了解下
    2020-10-10
  • 利用Python實現(xiàn)電影訂票系統(tǒng)

    利用Python實現(xiàn)電影訂票系統(tǒng)

    這篇文章主要介紹了利用Python實現(xiàn)電影訂票系統(tǒng),一部電影的詳細信息適合用?字典?結構來存儲,我們可以給字典里添加多個鍵值對來保存電影的名稱、座位表和宣傳時用的字符畫,需要的朋友可以參考一下
    2022-03-03
  • python目標檢測YoloV4當中的Mosaic數(shù)據(jù)增強方法

    python目標檢測YoloV4當中的Mosaic數(shù)據(jù)增強方法

    這篇文章主要為大家介紹了python目標檢測YoloV4當中的Mosaic數(shù)據(jù)增強方法,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-05-05
  • 詳解python對象之間的交互

    詳解python對象之間的交互

    這篇文章主要介紹了詳解python對象之間的交互,幫助大家更好的理解和使用python,感興趣的朋友可以了解下
    2020-09-09
  • Python實現(xiàn)計算最小編輯距離

    Python實現(xiàn)計算最小編輯距離

    這篇文章主要介紹了Python實現(xiàn)計算最小編輯距離的相關代碼,有需要的小伙伴可以參考下
    2016-03-03
  • Python實現(xiàn)語音識別和語音合成功能

    Python實現(xiàn)語音識別和語音合成功能

    聲音的本質(zhì)是震動,震動的本質(zhì)是位移關于時間的函數(shù),波形文件(.wav)中記錄了不同采樣時刻的位移。這篇文章主要介紹了Python實現(xiàn)語音識別和語音合成,需要的朋友可以參考下
    2019-09-09

最新評論