国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

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

Python 忽略文件名編碼的方法

瀏覽:13日期:2022-07-15 14:43:25

問題

你想使用原始文件名執(zhí)行文件的I/O操作,也就是說文件名并沒有經(jīng)過系統(tǒng)默認(rèn)編碼去解碼或編碼過。

解決方案

默認(rèn)情況下,所有的文件名都會根據(jù) sys.getfilesystemencoding() 返回的文本編碼來編碼或解碼。比如:

>>> sys.getfilesystemencoding()’utf-8’>>>

如果因?yàn)槟撤N原因你想忽略這種編碼,可以使用一個原始字節(jié)字符串來指定一個文件名即可。比如:

>>> # Wrte a file using a unicode filename>>> with open(’jalapexf1o.txt’, ’w’) as f:... f.write(’Spicy!’)...6>>> # Directory listing (decoded)>>> import os>>> os.listdir(’.’)[’jalapeño.txt’]>>> # Directory listing (raw)>>> os.listdir(b’.’) # Note: byte string[b’jalapenxccx83o.txt’]>>> # Open file with raw filename>>> with open(b’jalapenxccx83o.txt’) as f:... print(f.read())...Spicy!>>>

正如你所見,在最后兩個操作中,當(dāng)你給文件相關(guān)函數(shù)如 open() 和 os.listdir() 傳遞字節(jié)字符串時,文件名的處理方式會稍有不同。

討論

通常來講,你不需要擔(dān)心文件名的編碼和解碼,普通的文件名操作應(yīng)該就沒問題了。 但是,有些操作系統(tǒng)允許用戶通過偶然或惡意方式去創(chuàng)建名字不符合默認(rèn)編碼的文件。 這些文件名可能會神秘地中斷那些需要處理大量文件的Python程序。

讀取目錄并通過原始未解碼方式處理文件名可以有效的避免這樣的問題, 盡管這樣會帶來一定的編程難度。

關(guān)于打印不可解碼的文件名,請參考

以上就是Python 忽略文件名編碼的方法的詳細(xì)內(nèi)容,更多關(guān)于Python 忽略文件名編碼的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 剑阁县| 久治县| 乌恰县| 南丹县| 秦安县| 拜泉县| 泸西县| 宣化县| 肇州县| 永德县| 正安县| 抚宁县| 西吉县| 德钦县| 香格里拉县| 进贤县| 余姚市| 娄烦县| 上蔡县| 裕民县| 浮山县| 滕州市| 渑池县| 名山县| 方山县| 布尔津县| 社旗县| 定远县| 石嘴山市| 永春县| 临江市| 兖州市| 共和县| 克什克腾旗| 蓝山县| 怀仁县| 枣阳市| 白河县| 克东县| 台山市| 宜春市|