色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術(shù)文章
文章詳情頁

Python寫腳本常用模塊OS基礎(chǔ)用法詳解

瀏覽:9日期:2022-06-24 10:07:27

收集了一些關(guān)于OS庫的用法,整理歸納一下,方便使用

import os# 系統(tǒng)操作print(os.sep) # 獲取當(dāng)前系統(tǒng)的路徑分隔符print(os.name) # 獲取當(dāng)前使用的工作平臺(tái)print(os.getenv(’PATH’)) # 獲取名為 PATH 的環(huán)境變量print(os.getcwd()) # 獲取當(dāng)前的路徑print(os.environ[’PATH’]) # 可以返回環(huán)境相關(guān)的信息 不傳參時(shí),以字典的方式返回所有環(huán)境變量# 調(diào)用系統(tǒng)命令os.system(command) # 將linux命令傳入這里,就可以執(zhí)行 Execute the command in a subshell. # 目錄操作 - 增刪改查dir = '/opt/'listdir_opt = os.listdir(dir) # 返回指定目錄下的所有文件何目錄名print(listdir_opt) os.mkdir('/opt/os-make/') # 創(chuàng)建一個(gè)目錄,只創(chuàng)建一個(gè)目錄文件os.mknod('/root/python-test.txt') # 創(chuàng)建一個(gè)文件os.rmdir('/opt/ooo/') # 刪除一個(gè)空目錄,若目錄中有文件則無法刪除os.remove('/tmp/test.txt') # 用于刪除文件,若是目錄,則拋出 IsDirectoryError 異常os.makedirs('/opt/os-make-again/os-make-again-again') # 可以生成多層遞歸目錄,如果目錄全部存在,則創(chuàng)建目錄失敗os.removedirs() # 從最下級(jí)目錄開始,逐級(jí)刪除指定路徑,遇到非空目錄即停止os.chdir('/tmp/') # 改變當(dāng)前目錄,到指定目錄os.rename('/opt/ooo/','/opt/AAA/') # 重命名目錄名或者文件名。重命名后的文件已存在,則重命名失敗。'''os.rename()函數(shù)的作用是將文件或路徑重命名,一般調(diào)用格式為os.rename(src, dst),即將src指向的文件或路徑重命名為dst指定的名稱。注意,如果指定的目標(biāo)路徑在其他目錄下,該函數(shù)還可實(shí)現(xiàn)文件或路徑的“剪切并粘貼”功能。但無論直接原地重命名還是“剪切粘貼”,中間路徑都必須要存在,否則就會(huì)拋出FileNotFoundError異常。如果目標(biāo)路徑已存在,Windows 下會(huì)拋出FileExistsError異常;Linux 下,如果目標(biāo)路徑為空且用戶權(quán)限允許,則會(huì)靜默覆蓋原路徑,否則拋出OSError異常,和上兩個(gè)函數(shù)一樣,該函數(shù)也有對(duì)應(yīng)的遞歸版本os.renames(),能夠創(chuàng)建缺失的中間路徑。注意,這兩種情況下,如果函數(shù)執(zhí)行成功,都會(huì)調(diào)用os.removedir()函數(shù)來遞歸刪除源路徑的最下級(jí)目錄。'''# 判斷if os.path.exists('/root'): print('/root 目錄存在!')if os.path.isfile('/root'): print('/root 文件存在!')if os.path.isdir('/etc'): print('/etc 目錄存在!')if os.path.isabs('/etc'): print('/etc 是絕對(duì)路徑!')# path模塊'''os.path中的函數(shù)基本上是純粹的字符串操作。換句話說,傳入該模塊函數(shù)的參數(shù)甚至不需要是一個(gè)有效路徑,該模塊也不會(huì)試圖訪問這個(gè)路徑,而僅僅是按照“路徑”的通用格式對(duì)字符串進(jìn)行處理。'''path = '/etc/passwd'filename = os.path.basename(path) # 返回文件名,如果是目錄則為空 實(shí)際上是傳入路徑最后一個(gè)分隔符之后的子字符串,也就是說,如果最下級(jí)目錄之后還有一個(gè)分隔符,得到的就會(huì)是一個(gè)空字符串filedir = os.path.dirname(path) # 返回的是最后一個(gè)分隔符前的整個(gè)字符串filesplit = os.path.split(path) # 將傳入路徑以最后一個(gè)分隔符為界,分成兩個(gè)字符串,并打包成元組的形式返回'''類似的os.path.splitext('ooo.txt')(’ooo’, ’.txt’)'''filesize = os.path.getsize(path) # 獲取文件的大小 相當(dāng)于 ls -l 單位為bytesfileAbsPath = os.path.abspath(path) # 獲取文件的絕對(duì)路徑filejoin = os.path.join(path,'test.txt') # 拼接新的路徑'''如果傳入路徑中存在一個(gè)“絕對(duì)路徑”格式的字符串,且這個(gè)字符串不是函數(shù)的第一個(gè)參數(shù),那么其他在這個(gè)參數(shù)之前的所有參數(shù)都會(huì)被丟棄,余下的參數(shù)再進(jìn)行組合。更準(zhǔn)確地說,只有最后一個(gè)“絕對(duì)路徑”及其之后的參數(shù)才會(huì)體現(xiàn)在返回結(jié)果中。例子如下:os.path.join('just', 'do', '/opt/', 'it')結(jié)果: /opt/itos.path.join('just', 'do', '/opt/', 'python', 'dot', '/root', 'com')結(jié)果:/root/com'''print(filename+'n'+filedir+'n'+str(filesize)+'n'+fileAbsPath+'n'+filejoin+'n')

以上模塊和函數(shù)的用法已經(jīng)做了一些說明,理解起來也不難,下面再介紹一個(gè)函數(shù)os.walk()

import osfor item in os.walk('/opt/test-walk/'): print(item)

程序輸出結(jié)果

(’/opt/test-walk/’, [’a’, ’b’, ’c’], [])(’/opt/test-walk/a’, [], [’a.txt’])(’/opt/test-walk/b’, [’b2’], [])(’/opt/test-walk/b/b2’, [], [’b.txt’])(’/opt/test-walk/c’, [], [])

目錄結(jié)構(gòu)

[root@open-1 python_scripts]# tree /opt/test-walk//opt/test-walk/├── a│ └── a.txt├── b│ └── b2│ └── b.txt└── c4 directories, 2 files

由上面的結(jié)果可以大致明白o(hù)s.walk()函數(shù)的作用:這個(gè)函數(shù)需要傳入一個(gè)路徑作為參數(shù),函數(shù)的作用是在該路徑為根節(jié)點(diǎn)的目錄樹中游走,對(duì)樹中的每個(gè)目錄生成一個(gè)由(dirpath, dirnames, filenames)三項(xiàng)組成的三元組。其中,dirpath是一個(gè)指示這個(gè)目錄路徑的字符串,dirnames是一個(gè)dirpath下子目錄名(除去 . 和 ..)組成的列表,filenames則是由dirpath下所有非目錄的文件名組成的列表。簡單來說,就是把目標(biāo)路徑下的所有目錄和文件都列出來,結(jié)合tree命令的結(jié)果,就更好理解這個(gè)函數(shù)的作用了.

----------------------練習(xí)------------------------

在當(dāng)前目錄新建目錄img, 里面包含多個(gè)文件, 文件名各不相同(X4G5.png)

將當(dāng)前img目錄所有以.png結(jié)尾的后綴名改為.jpg

import randomimport stringimport osdef gen_code(len=4): # 隨機(jī)生成4位驗(yàn)證碼 li = random.sample(string.ascii_letters+string.digits,len) return ’’.join(li)def create_file(): # 隨機(jī)生成100個(gè)驗(yàn)證碼 li = {gen_code() for i in range(100)} os.mkdir(’img’) for name in li: os.mknod(’img/’ + name + ’.png’)create_file()def modify_suffix(dirname,old_suffix,new_suffix): ''' :param dirname:操作的目錄 :param old_suffix: 之前的后綴名 :param new_suffix: 新的后綴名 :return: ''' # 1.判斷查找的目錄是否存在,如果不存在,報(bào)錯(cuò) if os.path.exists(dirname): # 2.找出所有以old_suffix(.png)結(jié)尾的文件 pngfile = [filename for filename in os.listdir(dirname) if filename.endswith(old_suffix)] # 3.將后綴名和文件名分開,留下文件名 basefiles = [os.path.splitext(filename)[0] for filename in pngfile] # 4.重命名文件 for filename in basefiles: oldname = os.path.join(dirname,filename+old_suffix) newname = os.path.join(dirname,filename+new_suffix) os.rename(oldname,newname) print(’%s命名為%s成功’ %(oldname,newname)) else: print(’%s不存在,不能操作...’ %(dirname))modify_suffix(’redhat’,’.jpg’,’.png’)

-----------------練習(xí)-----------------------

利用time.time()方法,我們可以計(jì)算兩個(gè)時(shí)間點(diǎn)之間的時(shí)間間隔

但是有些時(shí)候我們想要得到/etc/group文件的a/c/m的時(shí)間對(duì)應(yīng)的年月日這些信息并保存再文件date.txt文件中

import osimport timetime1 = os.path.getctime(’/etc/shadow’) #時(shí)間戳?xí)r間print(time1)tuple_time = time.localtime(time1)print(tuple_time)year = tuple_time.tm_yearmonth = tuple_time.tm_monday = tuple_time.tm_mdaywith open(’date.txt’,’a’) as f: f.write(’%d %d %d’ %(year,month,day)) f.write(’n’)

到此這篇關(guān)于Python寫腳本常用模塊OS基礎(chǔ)用法詳解的文章就介紹到這了,更多相關(guān)Python 模塊OS使用內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 看欧美毛片一级毛片 | 亚洲国产成人久久综合碰 | 黄色资源网址 | 97天天干 | 欧美一级毛片欧美一级成人毛片 | 一级性毛片 | 欧美日韩国产一区二区三区在线观看 | 欧美xxxxx色视频在线观看 | 欧美成人免费全部观看天天性色 | 欧美在线观看成人高清视频 | 欧美成人香蕉网在线观看 | 亚洲 欧美 日韩中文字幕一区二区 | 精品一区二区三区在线视频观看 | 性日韩精品 | 亚洲欧美在线视频免费 | 久久er国产精品免费观看1 | 男人的天堂毛片 | 成人区精品一区二区不卡亚洲 | 国产免费黄色网址 | 亚洲黄色美女视频 | 国产精品免费视频一区 | 成人看片免费 | 亚洲手机在线观看 | 91精品国产福利尤物免费 | 国产区久久 | 国产成人免费高清视频 | 狠狠五月深爱婷婷网 | 国产精品视频男人的天堂 | 欧美成人精品福利在线视频 | 久久久久欧美精品 | 国产精品分类视频分类一区 | 欧美精品v日韩精品v国产精品 | 久久久久久久久网站 | 久久久久久全国免费观看 | 一区在线免费 | 久久e | 久久99这里只有精品国产 | 日美三级| 深夜做爰性大片很黄很色视频 | 国内精品不卡一区二区三区 | 国产亚洲精品高清在线 |