溫馨提示×

溫馨提示×

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

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

Python類有哪些

發(fā)布時間:2021-11-03 16:45:30 來源:億速云 閱讀:125 作者:iii 欄目:編程語言

本篇內(nèi)容介紹了“Python類有哪些”的有關(guān)知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細閱讀,能夠?qū)W有所成!

shutil:

shutil.copyfile( src, dst)   #從源src復(fù)制到dst中去。 如果當(dāng)前的dst已存在的話就會被覆蓋掉

shutil.move( src, dst)  #移動文件或重命名

shutil.copymode( src, dst) #只是會復(fù)制其權(quán)限其他的東西是不會被復(fù)制的

shutil.copystat( src, dst) #復(fù)制權(quán)限、最后訪問時間、最后修改時間

shutil.copy( src, dst)  #復(fù)制一個文件到一個文件或一個目錄

shutil.copy2( src, dst)  #在copy上的基礎(chǔ)上再復(fù)制文件最后訪問時間與修改時間也復(fù)制過來了,類似于cp –p的東西

shutil.copy2( src, dst)  #如果兩個位置的文件系統(tǒng)是一樣的話相當(dāng)于是rename操作,只是改名;如果是不在相同的文件系統(tǒng)的話就是做move操作

shutil.copytree( olddir, newdir, True/Flase) #把olddir拷貝一份newdir,如果第3個參數(shù)是True,則復(fù)制目錄時將保持文件夾下的符號連接,如果第3個參數(shù)是False,則將在復(fù)制的目錄下生成物理副本來替代符號連接

shutil.rmtree( src )   #遞歸刪除一個目錄以及目錄內(nèi)的所有內(nèi)容

subprocess

subprocess 模塊允許我們啟動一個新進程,并連接到它們的輸入/輸出/錯誤管道,從而獲取返回值。

使用 subprocess 模塊

subprocess 模塊首先推薦使用的是它的 run 方法,更高級的用法可以直接使用 Popen 接口。

run 方法語法格式如下:

subprocess.run(args, *, stdin=None, input=None, stdout=None, stderr=None, capture_output=False, shell=False, cwd=None, timeout=None, check=False, encoding=None, errors=None, text=None, env=None, universal_newlines=None)

args:表示要執(zhí)行的命令。必須是一個字符串,字符串參數(shù)列表。

stdin、stdout 和 stderr:子進程的標(biāo)準(zhǔn)輸入、輸出和錯誤。其值可以是 subprocess.PIPE、subprocess.DEVNULL、一個已經(jīng)存在的文件描述符、已經(jīng)打開的文件對象或者 None。subprocess.PIPE 表示為子進程創(chuàng)建新的管道。subprocess.DEVNULL 表示使用 os.devnull。默認(rèn)使用的是 None,表示什么都不做。另外,stderr 可以合并到 stdout 里一起輸出。

timeout:設(shè)置命令超時時間。如果命令執(zhí)行時間超時,子進程將被殺死,并彈出 TimeoutExpired 異常。

check:如果該參數(shù)設(shè)置為 True,并且進程退出狀態(tài)碼不是 0,則彈 出 CalledProcessError 異常。

encoding: 如果指定了該參數(shù),則 stdin、stdout 和 stderr 可以接收字符串?dāng)?shù)據(jù),并以該編碼方式編碼。否則只接收 bytes 類型的數(shù)據(jù)。

shell:如果該參數(shù)為 True,將通過操作系統(tǒng)的 shell 執(zhí)行指定的命令。

run 方法調(diào)用方式返回 CompletedProcess 實例,和直接 Popen 差不多,實現(xiàn)是一樣的,實際也是調(diào)用 Popen,與 Popen 構(gòu)造函數(shù)大致相同,例如:

實例

#執(zhí)行l(wèi)s -l /dev/null 命令

>>> subprocess.run(["ls", "-l", "/dev/null"])

crw-rw-rw-  1 root  wheel    3,   2  5  4 13:34 /dev/null

CompletedProcess(args=['ls', '-l', '/dev/null'], returncode=0)

returncode: 執(zhí)行完子進程狀態(tài),通常返回狀態(tài)為0則表明它已經(jīng)運行完畢,若值為負值 "-N",表明子進程被終。

簡單實例:

實例

import subprocess

def runcmd(command):

    ret = subprocess.run(command,shell=True,stdout=subprocess.PIPE,stderr=subprocess.PIPE,encoding="utf-8",timeout=1)

    if ret.returncode == 0:

        print("success:",ret)

    else:

        print("error:",ret)

runcmd(["dir","/b"])#序列參數(shù)

runcmd("exit 1")#字符串參數(shù)

輸出結(jié)果如下:

success: CompletedProcess(args=['dir', '/b'], returncode=0, stdout='test.py\n', stderr='')

error: CompletedProcess(args='exit 1', returncode=1, stdout='', stderr='')

Popen() 方法

Popen 是 subprocess的核心,子進程的創(chuàng)建和管理都靠它處理。

構(gòu)造函數(shù):

class subprocess.Popen(args, bufsize=-1, executable=None, stdin=None, stdout=None, stderr=None, 

preexec_fn=None, close_fds=True, shell=False, cwd=None, env=None, universal_newlines=False, 

startupinfo=None, creationflags=0,restore_signals=True, start_new_session=False, pass_fds=(),

*, encoding=None, errors=None)

常用參數(shù):

args:shell命令,可以是字符串或者序列類型(如:list,元組)

bufsize:緩沖區(qū)大小。當(dāng)創(chuàng)建標(biāo)準(zhǔn)流的管道對象時使用,默認(rèn)-1。

0:不使用緩沖區(qū)

1:表示行緩沖,僅當(dāng)universal_newlines=True時可用,也就是文本模式

正數(shù):表示緩沖區(qū)大小

負數(shù):表示使用系統(tǒng)默認(rèn)的緩沖區(qū)大小。

stdin, stdout, stderr:分別表示程序的標(biāo)準(zhǔn)輸入、輸出、錯誤句柄

preexec_fn:只在 Unix 平臺下有效,用于指定一個可執(zhí)行對象(callable object),它將在子進程運行之前被調(diào)用

shell:如果該參數(shù)為 True,將通過操作系統(tǒng)的 shell 執(zhí)行指定的命令。

cwd:用于設(shè)置子進程的當(dāng)前目錄。

env:用于指定子進程的環(huán)境變量。如果 env = None,子進程的環(huán)境變量將從父進程中繼承。

創(chuàng)建一個子進程,然后執(zhí)行一個簡單的命令:

實例

>>> import subprocess

>>> p = subprocess.Popen('ls -l', shell=True)

>>> total 164

-rw-r--r--  1 root root   133 Jul  4 16:25 admin-openrc.sh

-rw-r--r--  1 root root   268 Jul 10 15:55 admin-openrc-v3.sh

...

>>> p.returncode

>>> p.wait()

0

>>> p.returncode

這里也可以使用 p = subprocess.Popen(['ls', '-cl']) 來創(chuàng)建子進程。

Popen 對象方法

poll(): 檢查進程是否終止,如果終止返回 returncode,否則返回 None。

wait(timeout): 等待子進程終止。

communicate(input,timeout): 和子進程交互,發(fā)送和讀取數(shù)據(jù)。

send_signal(singnal): 發(fā)送信號到子進程 。

terminate(): 停止子進程,也就是發(fā)送SIGTERM信號到子進程。

kill(): 殺死子進程。發(fā)送 SIGKILL 信號到子進程。

實例

import time

import subprocess

def cmd(command):

    subp = subprocess.Popen(command,shell=True,stdout=subprocess.PIPE,stderr=subprocess.PIPE,encoding="utf-8")

    subp.wait(2)

    if subp.poll() == 0:

        print(subp.communicate()[1])

    else:

        print("失敗")

cmd("java -version")

cmd("exit 1")

輸出結(jié)果如下:

java version "1.8.0_31"

Java(TM) SE Runtime Environment (build 1.8.0_31-b13)

Java HotSpot(TM) 64-Bit Server VM (build 25.31-b07, mixed mode)

失敗

信號模塊signal

盡管signal是Python中的模塊,但主要針對UNIX平臺,而Windows內(nèi)核中由于對信號機制支持不充分,所以在Windows上的Python不能發(fā)會信號系統(tǒng)的功能。

Python的signal模塊負責(zé)程序內(nèi)部的信號處理,典型的操作包括信號處理函數(shù)、暫停并等待信號,定時發(fā)出SIGALRM等。

加載模塊

import signal

信號名稱

# 連接掛斷

signal.SIGUP

# 非法指令

signal.SIGILL

# 終止進程

signal.SIGINT

SIGINT信號編號為2,當(dāng)按下鍵盤CTRL+c組合鍵時進程會收到此信號,用于終止進程。

# 暫停進程CTRL+z

signal.SIGSTP

# 殺死進程,此信號不能被捕獲或忽略。

signal.SIGKILL

SIGKILL信號用于強制殺死進程,此信號進程無法忽視,直接在系統(tǒng)層面將進程殺死,所以在Python中它是不能監(jiān)聽的。

# 終端退出

signal.SIGQUIT

# 終止信號,軟件終止信號。

signal.SIGTERM

當(dāng)終端用戶輸入kill sigerm pid時對應(yīng)PID的進程會接收到此信號,此信號進程是可以捕獲并指定函數(shù)處理。比如做一下程序清理等工作,當(dāng)然也是可以忽視此信號的。

# 鬧鐘信號,由signal.alarm()發(fā)起。

signal.SIGALRM

# 繼續(xù)執(zhí)行暫停進程

signal.SIGCONT

信號處理函數(shù)

設(shè)置發(fā)送SIGALRM信號的定時器

signal.alarm(time)

功能:在time秒后向進程自身發(fā)送SIGALRM信號

參數(shù):time為時間參數(shù),單位為秒。

例如:設(shè)置時鐘

$ vim sigalrm.py

#!/usr/bin/env python

# -*- coding:utf-8 -*-

import signal, time

# 3秒后終止程序

signal.alarm(3)

while True:

    time.sleep(1)

    print("working")

$ python sigalrm.py

working

working

鬧鐘

一個進程中只能設(shè)置一個時鐘,如果設(shè)置第二個則會覆蓋第一個的時間,并返回第一個的剩余時間,同時第一個鬧鐘返回為0。

例如:當(dāng)在一個程序中出現(xiàn)兩個signal.alarm()函數(shù)時

$ vim sigalrm.py

#!/usr/bin/env python

# -*- coding:utf-8 -*-

import signal, time

# 3秒后終止程序

print(signal.alarm(3)) # output:0

time.sleep(1)

print(signal.alarm(3)) # output:2

while True:

    time.sleep(1)

    print("working")

$ python sigalrm.py

0

2

working

working

鬧鐘

使用signal.pause阻塞函數(shù),讓進程暫停以等待信號,也就時阻塞進程執(zhí)行,簡單來說當(dāng)接收到信號后使進程停止。

例如:

$ vim sigalrm.py

#!/usr/bin/env python

# -*- coding:utf-8 -*-

import signal, time

# 3秒后終止程序

print(signal.alarm(3)) # output:0

time.sleep(1)

print(signal.alarm(3)) # output:2

# 阻塞等待信號的發(fā)生,無論什么信號都可以。

signal.pause()

while True:

    time.sleep(1)

    print("working")

$ python sigalrm.py

0

2

鬧鐘

使程序進入休眠

signal.pause()

作用:使程序進入休眠直到程序接收到某個信號量

獲取當(dāng)前程序注冊signalnum信號量的處理函數(shù)

signal.getsignal(signalnum)

作用:獲取當(dāng)前程序注冊signalnum信號量的處理函數(shù)

返回值:可能使Python可調(diào)用對象如signal.SIG_DFL、signal.SIG_IGN、None。

設(shè)置信號處理函數(shù)

signal.signal(sig, handler)

功能:按照handler處理器制定的信號處理方案處理函數(shù)

參數(shù):

sig擬需處理的信號 ,處理信號只針對這一種信號其作用。

handler信號處理方案,進程可以無視信號采取默認(rèn)操作也可自定義操作。

當(dāng)handler為下列函數(shù)時將有如下操作

SIG_IGN信號被無視ignore或忽略

SIG_DFL進程采用默認(rèn)default行為處理

function處理器handler作為函數(shù)名稱時,進程采用自定義函數(shù)處理。

SIGSTOP SIGKILL不能處理只能采用

例如:

$ vim signal.py

#!/usr/bin/env python

# -*- coding:utf-8 -*-

import signal, time

# 3秒后終止程序

signal.alarm(3)

# 當(dāng)遇到SIGINT即CTRL+C時忽略SIG_IGN

signal.signal(signal.SIGINT, signal.SIG_IGN)

# 阻塞等待信號的發(fā)生,無論什么信號都可以。

signal.pause()

$ python signal.py

鬧鐘

信號攔截

為什么需要設(shè)置信號攔截呢?如果使用多線程或多協(xié)程,為了防止主線程結(jié)束而子線程和子協(xié)程還在運行,此時就需要使用signal模塊,使用signal模塊可以綁定一個處理函數(shù),當(dāng)接收步到信號的時候不會立即結(jié)束程序。

在Python中攔截信號通常有兩種方式

第一種是發(fā)出kill信號

# SIGTERM 表示關(guān)閉程序信號

signal.signal(signal.SIGTERM, self._term_handler)

第二種是發(fā)出CTRL+C信號

# SIGINT表示CTRL+C信號

signal.signal(signal.SIGINT, self._term_handler)

在多線程多協(xié)程的程序設(shè)計時,一般多線程或的多協(xié)程程序在設(shè)計時應(yīng)該設(shè)計一個程序終止標(biāo)記,當(dāng)收到終止信號的時候,讓終止標(biāo)記狀態(tài)由False修改為True,此時運行的程序只有終止標(biāo)記在False狀態(tài)下時才能夠以運行。如果由需要休眠的協(xié)程,還應(yīng)給協(xié)程增加一個休眠標(biāo)記,當(dāng)程序休眠的時候休眠標(biāo)記設(shè)置為True,當(dāng)收到終止信號的時候,不僅僅要把終止標(biāo)記設(shè)置為True,還要將休眠中的協(xié)程結(jié)束掉。

argparse:

argparse是python用于解析命令行參數(shù)和選項的標(biāo)準(zhǔn)模塊,類似于linux中的ls指令,后面可以跟著不同的參數(shù)選項以實現(xiàn)不同的功能,argparse就可以解析命令行然后執(zhí)行相應(yīng)的操作。

argparse 使用

使用argparse 配置命令行參數(shù)時,需要三步:

創(chuàng)建 ArgumentParser() 對象

調(diào)用 add_argument() 方法添加參數(shù)

使用 parse_args() 解析添加的參數(shù)

復(fù)制代碼

    parser = argparse.ArgumentParser()

    parser.add_argument("-p", "--port",

        dest='port',

        default="/dev/ttyUSB0",

        help="serial port where the MCU is connected to.)

    parser.add_argument("-v", "--version",

        dest='version',

        action='store_true',

        help="show the version number of this program and exit.")

    args = parser.parse_args()

復(fù)制代碼

某些情況下,你想將參數(shù)按照功能進行概念分組,以便用戶方便使用,比如寫操作的參數(shù)作為一個組,讀操作的參數(shù)作為一個組,可以使用 ArgumentParser.add_argument_group(title=None, description=None) 定義一個組。

1     info_group = parser.add_argument_group('Device information')

2     read_group = parser.add_argument_group('Read and compare functions')

3     write_group = parser.add_argument_group('Erase and write functions')

4     run_group = parser.add_argument_group('Code execution functions')

方法參數(shù)查找表

1.ArgumentParser類

class argparse.ArgumentParser(prog=None, usage=None, description=None, epilog=None, parents=[], formatter_class=argparse.HelpFormatter, prefix_chars=’-‘, fromfile_prefix_chars=None, argument_default=None, conflict_handler=’error’, add_help=True, allow_abbrev=True)

參數(shù):

    prog:程序的名字

    usage:默認(rèn)情況下,ArgumentParser依據(jù)它包含的參數(shù)計算出幫助信息

    description:這個參數(shù)給出程序做什么以及如何工作的簡短描述

    epilog:顯示額外的關(guān)于程序的描述

    parents:有時候,幾個解析器會共享一個共同的參數(shù)集。可以使用一個帶有所有共享參數(shù)的解析器傳遞給ArgumentParser的parents=參數(shù),而不用重復(fù)定義這些參數(shù)

    formatter_class:ArgumentParser對象允許通過指定一個格式化類來定制幫助信息的格式(argparse.RawDescriptionHelpFormatter、argparse.RawTextHelpFormatter、argparse.ArgumentDefaultsHelpFormatter、argparse.MetavarTypeHelpFormatter)

    prefix_chars:修改前綴符

    fromfile_prefix_chars:以任意一個給定字符開始的參數(shù)將被當(dāng)做文件,并且將被這些文件包含的參數(shù)替換

    argument_default:指定一個解析器范圍的參數(shù)默認(rèn)值

    allow_abbrev:允許使用縮寫(默認(rèn))

    conflict_handler:關(guān)于設(shè)置同一個選項具有兩個動作

    add_help

2.ArgumentParser對象add_argument()方法

ArgumentParser.add_argument(name or flags…[, action][, nargs][, const][, default][, type][, choices][, required][, help][, metavar][, dest])

參數(shù)

    name or flags:傳遞給add_argument() 的第一個參數(shù)因此必須是一個標(biāo)記序列或者一個簡單的參數(shù)名字

    action:指出應(yīng)該如何處理命令行參數(shù)(支持的操作:’store’ ,’store_const’,’store_true’,’store_false’,’append’,’append_const’,’count’,’help’,’version’)

    nargs:將一個動作與不同數(shù)目的命令行參數(shù)關(guān)聯(lián)在一起(支持的值:N,’?’,’*’,’+’)

    const:用于保存常量值,它們不是從命令行讀入但是是ArgumentParser 的動作所要求的

    default:其默認(rèn)值為None,指出如果命令行參數(shù)沒有出現(xiàn)時它們應(yīng)該是什么值

    type:允許任意必要的類型檢查并作類型轉(zhuǎn)換

    choices:某些命令行參數(shù)應(yīng)該從一個受限的集合中選擇

    required:如果要使得選項是必需的,可以指定True作為required=關(guān)鍵字參數(shù)的值給add_argument()

    help:包含參數(shù)簡短描述的字符串

    metavar:默認(rèn)情況下,對于位置參數(shù)直接使用dest的值,對于可選參數(shù)則將dest的值變?yōu)榇髮憽W⒁鈓etavar只會改變顯示出來的名字parse_args() 對象中屬性的名字仍然由dest的值決定。

    dest:對于位置參數(shù)的動作,dest 通常作為第一個參數(shù)提供給add_argument(),對于可選參數(shù)的動作,dest的動作通常從選項字符串推導(dǎo)出來,如:ArgumentParser生成的dest的值是將第一個長的選項字符串前面的–字符串去掉。如果沒有提供長選項字符串,dest的獲得則是將第一個短選項字符串前面的-字符去掉。任何內(nèi)部的-將被轉(zhuǎn)換為字符以確保字符串是合法的屬性名字。(即對于可選參數(shù),先找長的選項字符串,再找短選項字符串,并且內(nèi)部的-會被轉(zhuǎn)換為字符。)

Action類

class argparse.Action(option_strings, dest, nargs=None, const=None, default=None, type=None, choices=None, required=False, help=None, metavar=None)

3.ArgumentParser對象parse_args()方法

將參數(shù)字符串轉(zhuǎn)換成對象并設(shè)置成命名空間的屬性。返回構(gòu)成的命名空間。

之前對add_argument() 的調(diào)用完全決定了創(chuàng)建什么對象以及如何設(shè)置。

選項值語法,parse_args()方法支持幾種指定一個選項的值的方法:

    最簡單的方法是,將選項和它的值以兩個分開的參數(shù)傳遞

    對于長選項(名字長度超過一個字符的選項),選項和它的值還可以用一個單一的命令行參數(shù)傳遞,并用=分隔它們

    對于短選項(長度只有一個字符的選項),選項及其值可以連在一起

    幾個短選項可以連在一起僅使用一個-前綴,只要只有最后一個選項要求有值或者都不要有值

無效參數(shù)

在解析命令行的同時,parse_args()會檢查各種錯誤,包括有歧義的選項、不合法的類型、不合法的選項、錯誤的位置參數(shù)個數(shù)等等。當(dāng)它遇到此類錯誤時,會退出并跟隨用法信息一起打印出錯誤。

參數(shù)包含“ - ”

parse_args()方法每當(dāng)用戶犯了明確的錯誤時會努力給出錯誤信息,但是有些情況天生就有歧義。例如,命令行參數(shù)-1既可以是想指明一個選項也可以是想提供一個位置參數(shù)。這里parse_args()會非常小心:位置參數(shù)只有在它們看上去像負數(shù)且解析器中沒有選項看上去是負數(shù)時才可以以-開始。

如果你有必須以- 開始的位置參數(shù)且不是負數(shù),你可以插入偽參數(shù)’–’告訴parse_args()其后的所有內(nèi)容都為位置參數(shù)。

參數(shù)縮寫(前綴匹配)

參數(shù)不來自sys.argv

有時候可能需要ArgumentParser解析的參數(shù)不是來自sys.argv。這可以通過傳遞一個字符串列表給parse_args()來完成

4.class argparse.Namespace

parse_args() 默認(rèn)使用的簡單的類,用于創(chuàng)建一個保存屬性的對象并返回該對象。

有時可能需要讓ArgumentParser分配屬性給一個已經(jīng)存在的對象而不是一個新的Namespace對象。這可以通過指定namespace=關(guān)鍵字參數(shù)達到。

“Python類有哪些”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!

向AI問一下細節(jié)

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

AI