久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁技術文章
文章詳情頁

Python打印不合法的文件名

瀏覽:55日期:2022-07-15 15:21:58

問題

你的程序獲取了一個目錄中的文件名列表,但是當它試著去打印文件名的時候程序崩潰, 出現了 UnicodeEncodeError 異常和一條奇怪的消息—— surrogates not allowed 。

解決方案

當打印未知的文件名時,使用下面的方法可以避免這樣的錯誤:

def bad_filename(filename): return repr(filename)[1:-1]try: print(filename)except UnicodeEncodeError: print(bad_filename(filename))

如果你有代碼需要操作文件名或者將文件名傳遞給 open() 這樣的函數,一切都能正常工作。 只有當你想要輸出文件名時才會碰到些麻煩(比如打印輸出到屏幕或日志文件等)。 特別的,當你想打印上面的文件名列表時,你的程序就會崩潰:

>>> for name in files:... print(name)...spam.pyTraceback (most recent call last): File '<stdin>', line 2, in <module>UnicodeEncodeError: ’utf-8’ codec can’t encode character ’udce4’ inposition 1: surrogates not allowed>>>

>>> for name in files:... try:... print(name)... except UnicodeEncodeError:... print(bad_filename(name))...spam.pybudce4d.txtfoo.txt>>>

在 bad_filename() 函數中怎樣處置取決于你自己。 另外一個選擇就是通過某種方式重新編碼,示例如下:

def bad_filename(filename): temp = filename.encode(sys.getfilesystemencoding(), errors=’surrogateescape’) return temp.decode(’latin-1’)

譯者注:

surrogateescape:這種是Python在絕大部分面向OS的API中所使用的錯誤處理器,它能以一種優雅的方式處理由操作系統提供的數據的編碼問題。在解碼出錯時會將出錯字節存儲到一個很少被使用到的Unicode編碼范圍內。在編碼時將那些隱藏值又還原回原先解碼失敗的字節序列。它不僅對于OS API非常有用,也能很容易的處理其他情況下的編碼錯誤。

使用這個版本產生的輸出如下:

>>> for name in files:... try:... print(name)... except UnicodeEncodeError:... print(bad_filename(name))...spam.pybäd.txtfoo.txt>>>

這一小節主題可能會被大部分讀者所忽略。但是如果你在編寫依賴文件名和文件系統的關鍵任務程序時, 就必須得考慮到這個。否則你可能會在某個周末被叫到辦公室去調試一些令人費解的錯誤。

以上就是Python打印不合法的文件名的詳細內容,更多關于Python 打印文件名的資料請關注好吧啦網其它相關文章!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 沂源县| 嘉黎县| 通城县| 惠安县| 鲜城| 永丰县| 巴中市| 洛川县| 长治县| 新竹市| 绵竹市| 奉贤区| 彭阳县| 祁阳县| 大宁县| 元朗区| 利川市| 红河县| 漠河县| 咸丰县| 闵行区| 中江县| 延庆县| 佳木斯市| 靖宇县| 会宁县| 安泽县| 浦城县| 贵南县| 屯留县| 广西| 塔河县| 丹东市| 集安市| 金平| 习水县| 乳山市| 石城县| 长治县| 玉溪市| 鹰潭市|