整理這些技術筆記真的很花時間,如果你願意 關閉 Adblock 支持我,我會把這份感謝轉換成更多「踩坑轉避坑」的內容給你!ヽ(・∀・)ノ
從 JavaScript 角度學 Python(19) - JSON
前言
前面我們了解基本的檔案處理之後,接下來當然就是試著實作讀取一些不同格式的檔案,因此這一篇將會介紹我們前端工程師常用的 JSON 檔案。
JSON
對於一名前端工程師來講,相信 JSON (JavaScript Object Notation) 應該不會很陌生,但是如果你不清楚 JSON 的背景以及它的一些細節的話,那麼建議你可以閱讀我先前寫的這一篇「JavaScript 核心觀念(32)-物件-JSON」文章先稍微回顧惡補一下。
你看完了嗎?不,我相信你沒看。

前面開玩笑的,我說的是在場都是…(被揍)
那麼為了確保接下來的動作都正確,所以前面我還是簡單介紹一下關於 JSON 的部分。
首先先讓我們看一段簡易的 JSON 格式:
1 | |
發現了嗎?上面的 JSON 範例可以發現與 Python 的字典非常相像,這邊我也拉一個先前的 Python 字典範例給大家比較看看:
1 | |
可以發現單純只是雙引號變成單引號而已,甚至你把整個 JSON 拉過來 Python 運作都不會出現任何錯誤:
1 | |
這時候你可能會想說「所以我可以這樣寫入一個 JSON 格式囉?!」
身為工程師必須要有實驗的精神,因此這邊你可以試著輸入以下程式碼看看結果會怎麼樣:
1 | |
你嘗試了嗎?如果你有嘗試上面範例程式碼的話,你應該會出現這一段 TypeError: write() argument must be str, not dict 錯誤訊息。
最主要原因是 write 只接受純粹的 String 格式,此時異想天開的你或許會想說「那我就用 str 型別轉換就好了呀?」,實際上是不行的,如果你用這種方式的話,結果會變成一個錯誤的 JSON 格式:
1 | |
奇妙吧?畢竟你要知道一件事情 JSON 是 JavaScript 的子集(意指參照基於 JavaScript 延伸出來的),因此對於 JavaScript 的相容性會是最好的,因此如果你要用於 Python 的話,則必須使用另一個東西來處理。

JSON 模組
這邊先拉回到 JavaScript 的角度來簡單聊一下,通常我們在儲存一些資料到 localStorage 時都會搭配使用 JSON.stringify,而從 localStorage 拉出資料到 JavaScript 中就會使用 JSON.parse 來轉換回原本的 JavaScript 物件:
1 | |
那麼本身 Python 如果想要處理 JSON 格式的話,就必須引入 Python 的 JSON 模組:
1 | |
其中 JSON 模組中有 dumps 方法可以將 Python 的 dict 型別轉換成 JSON 格式,寫法與用法也相當的簡易,讓我們來看一下:
1 | |
發現了嗎?你可以正常的寫入一個 JSON 格式了呢!而且不會出現任何錯誤!

那麼反之讀取呢?雖然你可以直接這樣子讀取 JSON 格式:
1 | |
但是如果你要拿 JSON 格式的資料做一些處理的話,就必須使用 JSON 模組來轉換成 Python 可以讀的型別,否則 f.read() 出來的檔案型別會是一個 str(字串):
1 | |
那你可能會想說這樣會有什麼問題嗎?通常我們將 JSON 讀取後,可能會需要使用它某個欄位的屬性,那麼如果不透過 JSON 模組處理的話,你是無法取得特定屬性的,畢竟一整個都是一個 str 型別:
1 | |
因此當你取得 JSON 格式後,請記得使用 JSON 模組轉換成 Python 可以讀懂的型別:
1 | |
所以其實可以發現 JSON 格式的資料,不管是在 JavaScript 還是 Python 中都是必須額外處理的唷。
作者的話
因為家裡的人說喜歡我做的花雕醉雞…所以又跑去買了新的酒回來,但是這次打算嘗試製作紹興醉雞試試看,或許味道也不錯?!
關於兔兔們
- Tailwind CSS 臺灣官網
- Tailwind CSS 臺灣 (臉書粉絲專頁)
- 兔兔教 × Tailwind CSS Taiwan (臉書社群)
- 兔兔教大本營

整理這些技術筆記真的很花時間,如果你願意 關閉 Adblock 支持我,我會把這份感謝轉換成更多「踩坑轉避坑」的內容給你!ヽ(・∀・)ノ