您好,登錄后才能下訂單哦!
這篇“Python中的OS module如何使用”文章的知識點大部分人都不太理解,所以小編給大家總結了以下內容,內容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“Python中的OS module如何使用”文章吧。
Python的os模塊是用于與操作系統進行交互的標準庫之一,它提供了許多有用的函數和變量,以便處理文件和目錄。下面是一些常見的os模塊函數的用法:
1.獲取當前工作目錄:
import os cwd = os.getcwd() print(cwd)
2.切換當前工作目錄:
import os os.chdir('/path/to/new/directory')
3.列出目錄中的所有文件和子目錄:
import os files = os.listdir('/path/to/directory') print(files)
4.檢查給定的路徑是否為目錄:
import os path = '/path/to/directory' if os.path.isdir(path): print("It's a directory") else: print("It's not a directory")
5.檢查給定的路徑是否為文件:
import os path = '/path/to/file' if os.path.isfile(path): print("It's a file") else: print("It's not a file")
6.獲取文件的大小(以字節為單位):
import os path = '/path/to/file' size = os.path.getsize(path) print(size)
7.檢查給定的路徑是否存在:
import os path = '/path/to/file_or_directory' if os.path.exists(path): print("It exists") else: print("It doesn't exist")
8.創建新目錄:
import os path = '/path/to/new/directory' os.mkdir(path)
9.遞歸創建新目錄(如果目錄不存在):
import os path = '/path/to/new/directory' os.makedirs(path, exist_ok=True)
10.刪除文件或空目錄:
import os path = '/path/to/file_or_directory' os.remove(path)
11.遞歸刪除目錄及其內容:
import os path = '/path/to/directory' os.system('rm -rf ' + path)
其它一些便捷用法:
12.os.path.splitext() 方法是將一個路徑分割成文件名和擴展名兩部分。它會以文件名中的最后一個 "." 作為分隔符,將文件名和擴展名分開。例如,如果文件路徑為 "/path/to/file.txt",則 os.path.splitext() 方法會返回一個元組 ("/path/to/file", ".txt")。
需要注意的是,如果文件名中沒有 ".",則返回的擴展名為空字符串。如果文件名以 "." 開頭,則視為無擴展名文件,os.path.splitext() 方法將返回 (文件路徑, '')。
以下是一個例子:
import os path = '/path/to/file.txt' file_name, ext = os.path.splitext(path) print('文件名為:', file_name) print('擴展名為:', ext)
輸出結果為:
文件名為: /path/to/file
擴展名為: .txt
13.設置文件權限:
import os os.chmod('/path/to/file', 0o777) # 設置讀、寫、執行權限
os.chmod() 方法可以用來修改文件或目錄的訪問權限。它接受兩個參數:文件路徑和新的權限模式。權限模式可以使用八進制數表示,每個位表示不同的權限。
以下是一些權限模式的示例:
0o400:只讀權限
0o200:寫入權限
0o100:執行權限
0o700:所有權限
14.獲取CPU數量:
import os cpu_count = os.cpu_count() print('CPU數量為:', cpu_count)
需要注意的是,os.cpu_count() 返回的CPU數量是物理CPU核心數,并不包括超線程技術的虛擬核心。在具有超線程技術的系統中,每個物理CPU核心都會被劃分為兩個虛擬核心,因此os.cpu_count()方法可能會返回比實際CPU核心數多的數量。
另外,os.cpu_count()方法在不同的操作系統上可能會有不同的實現。在某些操作系統上,它可能只返回邏輯CPU核心數,而不是物理CPU核心數。因此,在使用該方法時,最好查閱相關的文檔以獲取更多信息。
15.啟動新進程:
import os os.system('notepad.exe')
os.system() 方法可以在操作系統上執行一個命令,并返回命令的退出狀態碼。它的參數是一個字符串類型的命令,可以是任何有效的系統命令。
以下是一個示例,演示了如何使用os.system()方法來執行一個簡單的命令:
import os os.system('echo "Hello, World!"')
上述代碼將輸出Hello, World!字符串,并返回命令的退出狀態碼(通常為0表示成功)。
需要注意的是,os.system() 方法會阻塞當前進程,直到命令執行完成。如果希望在執行命令時不阻塞當前進程,可以考慮使用subprocess模塊中的其他方法,如subprocess.Popen()。
以下是另一個示例,演示了如何使用os.system()方法來執行一個復雜的命令,比如在Linux系統上使用wget下載一個文件:
import os url = 'https://example.com/file.zip' output_dir = '/path/to/output' command = f'wget {url} -P {output_dir}' os.system(command)
上述代碼會將url參數指定的文件下載到output_dir參數指定的目錄中,并返回命令的退出狀態碼。
16.os.environ:這是一個包含當前環境變量的字典。可以使用os.environ[key]獲取特定環境變量的值。
17.os.exec*():這些方法允許Python程序在當前進程中執行其他程序,取代當前進程。例如,os.execv() 方法可以使用指定的參數列表執行一個程序,取代當前進程。
18.os.fork():這個方法可以在Unix或Linux操作系統上創建一個子進程,用于并行執行程序。子進程將復制父進程的所有內存內容,包括代碼、數據和堆棧等,因此可以在父進程的基礎上繼續執行程序。
19.os.kill():這個方法用于向指定進程發送信號。可以使用os.kill(pid, signal)方法向指定的進程發送指定的信號。常用的信號包括SIGINT(中斷信號)、SIGTERM(終止信號)和SIGKILL(強制終止信號)等。
20.os.pipe():這個方法可以創建一個管道,用于在進程之間進行通信。os.pipe()方法將返回兩個文件描述符,一個用于讀取管道數據,另一個用于寫入管道數據。
21.os.wait():這個方法可以等待子進程的結束,然后返回子進程的狀態碼。可以使用os.waitpid(pid, options)方法等待指定的進程結束,并返回進程的狀態碼。
22.os模塊可以用來操作文件路徑。例如,os.path.join(path, *paths)可以將多個路徑拼接成一個完整路徑,os.path.abspath(path)可以將相對路徑轉換為絕對路徑,os.path.split(path)可以將路徑分割成目錄和文件名。
23.遍歷目錄樹
import os def list_files(path): for root, dirs, files inos.walk(path): for file in files: print(os.path.join(root, file)) list_files('.')
這段代碼可以遍歷當前工作目錄及其子目錄下的所有文件,并打印出它們的完整路徑。
os.walk()是os模塊中一個非常有用的函數,用于遍歷指定目錄及其子目錄下的所有文件和目錄。它返回一個三元組(root, dirs, files),其中root是當前目錄的路徑,dirs是當前目錄下的子目錄列表,files是當前目錄下的文件列表。下面是一個os.walk()的詳細解釋和示例:
for root, dirs, files in os.walk(top, topdown=True, onerror=None, followlinks=False): # Do something with root, dirs, and files
top是指定的目錄路徑,可以是相對路徑或絕對路徑。
topdown是一個布爾值,表示遍歷時是否先遍歷當前目錄,再遍歷子目錄。如果為True(默認值),則先遍歷當前目錄,再遍歷子目錄;如果為False,則先遍歷子目錄,再遍歷當前目錄。
onerror是一個可選的錯誤處理函數,如果在遍歷過程中出現錯誤,則會調用這個函數。
followlinks是一個布爾值,表示是否跟隨符號鏈接。如果為True,則會跟隨符號鏈接遍歷目錄;如果為False(默認值),則會忽略符號鏈接。
在遍歷過程中,os.walk()會依次遍歷指定目錄及其子目錄下的所有文件和目錄,并返回當前目錄的路徑、子目錄列表和文件列表。可以通過遍歷返回的三元組來處理目錄和文件。例如,可以使用下面的代碼列出指定目錄下的所有文件和子目錄:
import os def list_files_and_dirs(path): for root, dirs, files in os.walk(path): print(f'Directory: {root}') for file in files: print(f' File: {os.path.join(root, file)}') for dir in dirs: print(f' Subdirectory: {os.path.join(root, dir)}') list_files_and_dirs('.')
這段代碼會遍歷當前工作目錄及其子目錄下的所有文件和目錄,并輸出相應的信息。
需要注意的是,os.walk()只會遍歷當前目錄及其子目錄下的文件和目錄,不會遍歷符號鏈接所指向的文件或目錄。如果需要遍歷符號鏈接所指向的文件或目錄,需要設置followlinks=True。
以上就是關于“Python中的OS module如何使用”這篇文章的內容,相信大家都有了一定的了解,希望小編分享的內容對大家有幫助,若想了解更多相關的知識內容,請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。