python實(shí)現(xiàn)json文件的增刪改操作方法
python實(shí)現(xiàn)json文件的增刪改
1.原始JSON文件
以下是一個(gè)例子,假設(shè)原始的JSON文件內(nèi)容如下:
{ "name": "Alice", "age": 30, "address": { "city": "Beijing", "street": "Main Street" }, "hobbies": ["reading", "swimming", "traveling"] }
2.修改操作
修改操作:
import json # 加載JSON文件 with open('example.json', 'r') as f: data = json.load(f) # 修改姓名 data['name'] = 'Bob' # 修改年齡 data['age'] = 35 # 修改住址 data['address']['city'] = 'Shanghai' data['address']['street'] = 'West Street' # 保存修改后的JSON文件 with open('example.json', 'w') as f: json.dump(data, f, indent=2) # 保持2個(gè)縮進(jìn)
3.刪除操作
刪除操作:
import json # 加載JSON文件 with open('example.json', 'r') as f: data = json.load(f) # 刪除愛好中的一個(gè) data['hobbies'].remove('reading') # 刪除整個(gè)address del data['address'] # 保存修改后的JSON文件 with open('example.json', 'w') as f: json.dump(data, f, indent=2)
4.新增操作
新增操作:
import json # 加載JSON文件 with open('example.json', 'r') as f: data = json.load(f) # 新增一個(gè)愛好 data['hobbies'].append('writing') # 新增一個(gè)電話號(hào)碼 data['phone'] = '13888888888' # 保存修改后的JSON文件 with open('example.json', 'w') as f: json.dump(data, f, indent=2)
5.三級(jí)目錄的一些數(shù)據(jù)修改
假設(shè)我們有一個(gè)JSON文件data.json
,包含三級(jí)目錄的一些數(shù)據(jù):
{ "users": [ { "name": "John", "age": 28, "pets": [ { "name": "Fluffy", "type": "cat" }, { "name": "Fido", "type": "dog" } ] }, { "name": "Mary", "age": 33, "pets": [ { "name": "Rex", "type": "dog" }, { "name": "Whiskers", "type": "cat" }, { "name": "Buddy", "type": "dog" } ] } ] }
現(xiàn)在,我們想修改第二個(gè)用戶的第一個(gè)寵物的名稱為"Smokey"??梢允褂靡韵麓a:
import json # 讀取JSON文件 with open('data.json', 'r') as f: data = json.load(f) # 獲取第二個(gè)用戶的第一個(gè)寵物 pet = data['users'][1]['pets'][0] # 修改寵物名稱 pet['name'] = 'Smokey' # 保存修改后的JSON文件 with open('data.json', 'w') as f: json.dump(data, f, indent=2)
運(yùn)行以上代碼后,data.json
文件的內(nèi)容將會(huì)變成:
{ "users": [ { "name": "John", "age": 28, "pets": [ { "name": "Fluffy", "type": "cat" }, { "name": "Fido", "type": "dog" } ] }, { "name": "Mary", "age": 33, "pets": [ { "name": "Smokey", "type": "dog" }, { "name": "Whiskers", "type": "cat" }, { "name": "Buddy", "type": "dog" } ] } ] }
在這個(gè)示例代碼中,我們首先使用json.load()
函數(shù)讀取data.json
文件。接著,我們使用data['users'][1]['pets'][0]
獲取第二個(gè)用戶的第一個(gè)寵物。然后,我們可以修改寵物的名稱,通過修改字典pet
的鍵值來實(shí)現(xiàn)。最后,我們使用json.dump()
函數(shù)將修改后的數(shù)據(jù)保存到原始的JSON文件中。
【err】 1.open()讀取文件提示:“UnicodeDecodeError”
“UnicodeDecodeError: ‘gbk’ codec can’t decode byte 0x80 in position 205: illegal multibyte sequence”
解決辦法1.
FILE_OBJECT= open(‘order.log’,‘r’, encoding=‘UTF-8’)
解決辦法2.
FILE_OBJECT= open(‘order.log’,‘rb’)
到此這篇關(guān)于python實(shí)現(xiàn)json文件的增刪改操作的文章就介紹到這了,更多相關(guān)python json文件的增刪改內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
scrapy爬蟲:scrapy.FormRequest中formdata參數(shù)詳解
這篇文章主要介紹了scrapy爬蟲:scrapy.FormRequest中formdata參數(shù)詳解,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-04-04python機(jī)器學(xué)習(xí)樸素貝葉斯算法及模型的選擇和調(diào)優(yōu)詳解
這篇文章主要為大家介紹了python機(jī)器學(xué)習(xí)樸素貝葉斯及模型的選擇和調(diào)優(yōu)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步2021-11-11keras 使用Lambda 快速新建層 添加多個(gè)參數(shù)操作
這篇文章主要介紹了keras 使用Lambda 快速新建層 添加多個(gè)參數(shù)操作,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-06-06利用Python實(shí)現(xiàn)網(wǎng)絡(luò)測試的腳本分享
這篇文章主要給大家介紹了關(guān)于利用Python實(shí)現(xiàn)網(wǎng)絡(luò)測試的方法,文中給出了詳細(xì)的示例代碼供大家參考學(xué)習(xí),對大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起看看吧。2017-05-05Python爬蟲模擬登陸嗶哩嗶哩(bilibili)并突破點(diǎn)選驗(yàn)證碼功能
這篇文章主要介紹了Python爬蟲模擬登陸嗶哩嗶哩(bilibili)并突破點(diǎn)選驗(yàn)證碼功能,本文通過圖文實(shí)例相結(jié)合給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-12-12Python守護(hù)進(jìn)程和腳本單例運(yùn)行詳解
本篇文章主要介紹了Python守護(hù)進(jìn)程和腳本單例運(yùn)行,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-01-01Python pyinotify日志監(jiān)控系統(tǒng)處理日志的方法
這篇文章主要介紹了Python pyinotify日志監(jiān)控系統(tǒng)處理日志的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-03-03