中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

python處理統一碼文件的方法是什么

發布時間:2022-01-07 14:37:40 來源:億速云 閱讀:247 作者:iii 欄目:編程語言

這篇文章主要講解了“python處理統一碼文件的方法是什么”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“python處理統一碼文件的方法是什么”吧!

對于自然語言處理的從業者,處理統一碼文件是一場噩夢,尤其是使用Windows操作系統。想象一下,當在編碼或解碼過程中遇到錯誤時的沮喪,例如:

UnicodeEncodeError: 'mbcs' codec can't decode characters in   positionUnicodeDecodeError: 'charmap' codec can't decode byte 0x90 in position

大多數時候,除非是這個領域經驗豐富的人,否則這樣的錯誤并不能提供足夠的信息。你可能會問為什么需要對字符進行編碼和解碼。我們可以從對統一碼的簡單解釋來回答這個問題。

基于官方python文檔,統一碼Unicode  (通用編碼字符集)是一種規范,旨在列出人類語言使用的每個字符,并為每個字符提供各自獨特的代碼。統一碼規范不斷被修訂和更新,以添加新的語言和符號。

因此,編碼和解碼是一種將字符從文本映射到字節的方法,反之亦然。這使得它們可在計算機之間傳輸,并在日常生活中使用。當擁有不同的操作系統集時,情況會更復雜。

此外,不同語言有各自的字符集,只能在特定字體下顯示。簡單而言,可以看作是將一個外文字符翻譯成機器能理解的字符。本文將探討一些可以用于處理Python中統一碼文件的方法,從可用模式和標準編碼來入手。

通過上下文管理器讀寫文件

打開文件最安全的方法是通過上下文管理器使用with語句。它將自動關閉文件,防止任何可能出現的問題。

with open('name.txt') as f:     f.readlines()

默認模式是'rt' ,即讀取和發送文件。可以使用以下代碼編寫:

with open('name.txt', 'w') as f:     f.write('Hello world!')

上面的代碼將改寫并截斷文件。在一些情況下,可能更喜歡使用模式 'a'而不是'w'。以下列表顯示了可用的完整模式:

  • r:打開閱讀(默認)

  • w:打開寫入,首先截斷文件

  • x:打開專屬創建,如果文件已經存在則失敗

  • a:打開寫入,如果文件存在,則添加到文件末尾

  • b:二進制模式

  • t:文本模式(默認)

  • +:打開一個磁盤文件進行更新(讀寫)

可以組合一些模式。如原始文檔中所述(https://docs.python.org/3.5/library/functions.html#open),對于二進制讀寫訪問,模式'w+b'  打開并將文件截斷為0字節。'r+b' 打開文件不會截斷。

Python中的標準編碼

在Python中指定編碼,只需在上下文管理器初始化期間傳入另一個參數。無論何時讀寫統一碼字符,都需要指定它。以下例子顯示了將統一碼文本添加到現有文件的正確方法:

with open('name.txt', 'a', encoding='utf8') as f: f.write('你好!')

如果不確定使用哪種編碼,只需輸入  utf8并檢查是否有誤。大多情況下,UTF-8對于編碼和解碼字符已經夠好了。然而在某些情況下,需要使用不同的編碼。

通過Notepad++檢查編碼類型

一般會更傾向使用Notepad++來查看文件內容。如果使用Notepad++打開一個文件,可以在用戶界面的右下角看到使用的編碼類型。

python處理統一碼文件的方法是什么

一個使用UTF-8編碼的示例文件

可以通過編碼菜單修改編碼,它接受大量最常用的編碼。

python處理統一碼文件的方法是什么

單擊編碼菜單時顯示下拉菜單的圖像

如果曾遇到過無法將文件轉換為另一種編碼的問題,或者即使正確地指定了某些編碼,也無法讀取,那么可以嘗試以下方法。雖然有點笨,但親測有效。

  • 用個人希望的編碼創建一個空的文本文件。

  • 從原始文件中復制所有內容。

  • 將其粘貼到新文件并保存。

大多數情況下,這將自動將所有字符轉換為新的編碼。請注意,如果不能根據新的編碼轉換字符,可能會造成數據丟失。

處理未知編碼中的字符

如果遇到無法識別編碼且字符未知的情況,可以嘗試修改錯誤參數來解決這個問題:

with open('name.txt', 'r', encoding='utf8', errors='ignore') as f:     f.readlines()

錯誤參數指的是如何處理編碼和解碼錯誤。請注意,此參數不能在二進制模式中使用。可用錯誤的處理程序有:

  • 嚴格:如果存在編碼錯誤,則會造成ValueError 異常。None的默認值有相同效果。

  • 忽略:忽略錯誤。注意,忽略編碼錯誤會導致數據丟失。

  • 替換:將替換標記(如'?')插入有畸形數據的位置。

  • surrogateescape:將統一碼私有使用區域中的任何不正確字節表示為代碼點,范圍從U+DC80到U+DCFF。當這個錯誤處理程序用于編寫數據時,這些私有代碼點將被轉為相同字節。這對于處理未知編碼的文件很有用。

  • xmlcharrefreplace:僅在寫入文件時受支持。不受編碼支持的字符將被替換為適當的可擴展標記語言的字符引用 &#nnn;。

  • backslashreplace:用Python的backslash轉義字符替換畸形數據。

  • namereplace:(僅在編寫時支持)替換不支持的 \N{...} 轉義字符。

在命令提示符中顯示統一碼字符

如果在Windows操作系統中運行命令提示符,那么在大多數情況下顯示統一碼字符都會有問題,出現如下圖所示的亂碼字符:

python處理統一碼文件的方法是什么

顯示亂碼字符的命令提示符

為了解決這個問題,需要將設置更改為正確的字體。

  • 右鍵單擊頂部菜單并單擊屬性。

  • 單擊字體菜單。

  • 將字體修改為可顯示字符的所需字體。例如,可以使用楷體來呈現中文字符。

python處理統一碼文件的方法是什么

命令提示符的字體屬性

打開一個有統一碼字符的文件路徑——通過pandas模塊適用于read_csv

這部分有點棘手,尤其是在使用某些特定Python模塊(如pandas)時。假設有以下非英語的文件路徑:

file_path = 'C:\path\to\數據分析\data.csv'

試圖通過read_csv讀取文件將會拋出錯誤,因為文件路徑包含統一碼字符。在Python中使用內置的open()函數不是問題所在。為了解決這個問題,需要先打開文件,然后傳遞給read_csv函數:

with open(file_path, 'r', encoding='utf-8') as f:     df = pd.read_csv(f, encoding='utf-8')

感謝各位的閱讀,以上就是“python處理統一碼文件的方法是什么”的內容了,經過本文的學習后,相信大家對python處理統一碼文件的方法是什么這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

紫金县| 晋宁县| 湘潭市| 化隆| 大厂| 尼木县| 津市市| 安泽县| 紫阳县| 宝山区| 嘉黎县| 徐汇区| 大理市| 马关县| 英超| 九江县| 南江县| 丰宁| 政和县| 麻栗坡县| 探索| 郎溪县| 磐安县| 郑州市| 焦作市| 松溪县| 建宁县| 太保市| 申扎县| 山东省| 泽普县| 中卫市| 嘉禾县| 体育| 兴山县| 阿城市| 密云县| 武隆县| 泗阳县| 华亭县| 平山县|