python讀寫json文件的簡單實現(xiàn)
JSON(JavaScript Object Notation) 是一種輕量級的數(shù)據(jù)交換格式。它基于ECMAScript的一個子集。 JSON采用完全獨立于語言的文本格式,但是也使用了類似于C語言家族的習慣(包括C、C++、Java、JavaScript、Perl、Python等)。這些特性使JSON成為理想的數(shù)據(jù)交換語言。易于人閱讀和編寫,同時也易于機器解析和生成(一般用于提升網(wǎng)絡傳輸速率)。
JSON在python中分別由list和dict組成。
這是用于序列化的兩個模塊:
- json: 用于字符串和python數(shù)據(jù)類型間進行轉換
- pickle: 用于python特有的類型和python的數(shù)據(jù)類型間進行轉換
Json模塊提供了四個功能:dumps、dump、loads、load
pickle模塊提供了四個功能:dumps、dump、loads、load
json dumps把數(shù)據(jù)類型轉換成字符串 dump把數(shù)據(jù)類型轉換成字符串并存儲在文件中 loads把字符串轉換成數(shù)據(jù)類型 load把文件打開從字符串轉換成數(shù)據(jù)類型
json是可以在不同語言之間交換數(shù)據(jù)的,而pickle只在python之間使用。json只能序列化最基本的數(shù)據(jù)類型,josn只能把常用的數(shù)據(jù)類型序列化(列表、字典、列表、字符串、數(shù)字、),比如日期格式、類對象!josn就不行了。而pickle可以序列化所有的數(shù)據(jù)類型,包括類,函數(shù)都可以序列化。
事例:
dumps:將python中的 字典 轉換為 字符串
import json test_dict = {'bigberg': [7600, {1: [['iPhone', 6300], ['Bike', 800], ['shirt', 300]]}]} print(test_dict) print(type(test_dict)) #dumps 將數(shù)據(jù)轉換成字符串 json_str = json.dumps(test_dict) print(json_str) print(type(json_str))
loads: 將 字符串 轉換為 字典
new_dict = json.loads(json_str) print(new_dict) print(type(new_dict))
dump: 將數(shù)據(jù)寫入json文件中
with open("../config/record.json","w") as f: json.dump(new_dict,f) print("加載入文件完成...")
load:把文件打開,并把字符串變換為數(shù)據(jù)類型
with open("../config/record.json",'r') as load_f: load_dict = json.load(load_f) print(load_dict) load_dict['smallberg'] = [8200,{1:[['Python',81],['shirt',300]]}] print(load_dict) with open("../config/record.json","w") as dump_f: json.dump(load_dict,dump_f)
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
python使用正則表達式去除中文文本多余空格,保留英文之間空格方法詳解
這篇文章主要介紹了python使用正則表達式去除中文文本多余空格,保留英文之間空格方法詳解,需要的朋友可以參考下2020-02-02Python Pyqt5多線程更新UI代碼實例(防止界面卡死)
這篇文章通過代碼實例給大家介紹了Python Pyqt5多線程更新UI防止界面卡死的問題,代碼簡單易懂,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧2021-12-12Python 中的參數(shù)傳遞、返回值、淺拷貝、深拷貝
這篇文章主要介紹了Python 中的參數(shù)傳遞、返回值、淺拷貝、深拷貝,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2019-06-06使用python創(chuàng)建生成動態(tài)鏈接庫dll的方法
這篇文章主要介紹了使用python創(chuàng)建生成動態(tài)鏈接庫dll的方法,本文通過示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-05-05Python實現(xiàn)求取表格文件某個區(qū)域內單元格的最大值
這篇文章主要介紹基于Python語言,基于Excel表格文件內某一列的數(shù)據(jù),計算這一列數(shù)據(jù)在每一個指定數(shù)量的行的范圍內(例如每一個4行的范圍內)的區(qū)間最大值的方法,需要的朋友可以參考下2023-08-08