久久久精品一区ed2k-女人被男人叉到高潮的视频-中文字幕乱码一区久久麻豆樱花-俄罗斯熟妇真实视频

pathlib如何使用

這期內容當中小編將會給大家?guī)碛嘘Ppathlib如何使用,文章內容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

公司主營業(yè)務:網(wǎng)站設計制作、成都網(wǎng)站建設、移動網(wǎng)站開發(fā)等業(yè)務。幫助企業(yè)客戶真正實現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競爭能力。成都創(chuàng)新互聯(lián)公司是一支青春激揚、勤奮敬業(yè)、活力青春激揚、勤奮敬業(yè)、活力澎湃、和諧高效的團隊。公司秉承以“開放、自由、嚴謹、自律”為核心的企業(yè)文化,感謝他們對我們的高要求,感謝他們從不同領域給我們帶來的挑戰(zhàn),讓我們激情的團隊有機會用頭腦與智慧不斷的給客戶帶來驚喜。成都創(chuàng)新互聯(lián)公司推出寶應免費做網(wǎng)站回饋大家。

統(tǒng)計文件個數(shù)

我們可以使用.iterdir方法獲取當前文件下的所以文件.

import pathlib
from collections import Counter
now_path = pathlib.Path.cwd()
gen = (i.suffix for i in now_path.iterdir())
print(Counter(gen))

輸出內容

Counter({'.py': 16, '': 11, '.txt': 1, '.png': 1, '.csv': 1})

通過配合使用collections模塊的Counter方法,我們獲取了當文件夾下文件類型情況。

前面我們說過glob模塊點這里了解【glob模塊的使用】,同樣的pathlib也有glob方法和rglob方法,不同的是glob模塊里的glob方法結果是列表形式的,iglob是生成器類型,在這里pathlib的glob模塊返回的是生成器類型,然后pathlib還有一個支持遞歸操作的rglob方法。

下面的這個操作我通過使用glob方法,設定規(guī)則進行文件的匹配。

import pathlib
from  collections import Counter
gen =(p.suffix for p in pathlib.Path.cwd().glob('*.py'))
print(Counter(gen))

展示目錄樹

下一個示例定義了一個函數(shù)tree(),該函數(shù)的作用是打印一個表示文件層次結構的可視樹,該樹以一個給定目錄為根。因為想列出其子目錄,所以我們要使用.rglob()方法:

import pathlib
from  collections import Counter
def tree(directory):
    print(f'+ {directory}')
    for path in sorted(directory.rglob('*')):
        depth = len(path.relative_to(directory).parts)
        spacer = '    ' * depth
        print(f'{spacer}+ {path.name}')

now_path = pathlib.Path.cwd()

if __name__ == '__main__':
    tree(now_path)

其中relative_to的方法的作用是返回path相對于directory的路徑。

parts方法可以返回路徑的各部分。例如

import pathlib
now_path = pathlib.Path.cwd()
if __name__ == '__main__':
    print(now_path.parts)

返回

('/', 'Users', 'chennan', 'pythonproject', 'demo')

獲取文件最后一次修改時間

iterdir(),.glob()和.rglob()方法非常適合于生成器表達式和列表理解。

使用stat()方法可以獲取文件的一些基本信息,使用.stat().st_mtime可以獲取文件最后一次修改的信息。

import pathlib
now_path = pathlib.Path.cwd()
from datetime import datetime
time, file_path = max((f.stat().st_mtime, f) for f in now_path.iterdir())
print(datetime.fromtimestamp(time), file_path)

甚至可以使用類似的表達式獲取上次修改的文件內容

import pathlib
from datetime import datetime
now_path =pathlib.Path.cwd()
result = max((f.stat().st_mtime, f) for f in now_path.iterdir())[1]
print(result.read_text())

.stat().st_mtime會返回文件的時間戳,可以使用datetime或者time模塊對時間格式進行進一步轉換。

其他內容

關于pathlib.Path格式路徑轉換為字符串類型。

因為通過pathlib模塊操作生成的路徑,不能直接應用字符串的一些操作,所以需要轉換成字符串,雖然可以使用str()函數(shù)進行轉換,但是安全性不高,建議使用os.fspath()方法,因為如果路徑格式非法的,可以拋出一個異常。str()就不能做到這一點。

拼接符號"/"背后的秘密

/運算符由__truediv__()方法定義。 實際上,如果你看一下pathlib的源代碼,你會看到類似的東西。

class PurePath(object):

    def __truediv__(self, key):
        return self._make_child((key,))

上述就是小編為大家分享的pathlib如何使用了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

網(wǎng)頁題目:pathlib如何使用
轉載來于:http://sd-ha.com/article32/geggpc.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供外貿建站、動態(tài)網(wǎng)站品牌網(wǎng)站設計、、移動網(wǎng)站建設微信小程序

廣告

聲明:本網(wǎng)站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

外貿網(wǎng)站制作