摘要:如果希望將 JSON 文件導(dǎo)入到 Redis 中,首先要做的就是連接到 redis 服務(wù)。
本文分享自華為云社區(qū)《Python將JSON格式文件導(dǎo)入 redis,多種方法》,作者: 夢(mèng)想橡皮擦 。
在導(dǎo)入前需要先確定你已經(jīng)安裝 Redis,并且可以啟動(dòng)相關(guān)服務(wù)。
windows 上啟動(dòng) redis 的命令是 redis-server.exe redis.windows.conf,效果圖如下:
使用 Python 連接 redis
如果希望將 JSON 文件導(dǎo)入到 Redis 中,首先要做的就是連接到 redis 服務(wù),實(shí)現(xiàn)步驟如下所示。
安裝 redis 與 導(dǎo)入
安裝 redis 庫(kù)
pip install redis
導(dǎo)入 redis 庫(kù)
import redis
使用代碼連接 Redis
通過(guò) redis 庫(kù)的 Redis 類(lèi)連接 Redis 服務(wù)器。
import redis r = redis.Redis(host='localhost', port=6379, db=0) print(r)
連接到本地 Redis 服務(wù)器,并使用默認(rèn)端口 6379,連接到數(shù)據(jù)庫(kù) 0,這里建議使用 redis desktop 工具同步進(jìn)行連接測(cè)試。
寫(xiě)入鍵值
連接成功后,可以使用 Redis 的命令來(lái)操作數(shù)據(jù),例如設(shè)置鍵值對(duì):
import redis r = redis.Redis(host='localhost', port=6379, db=15) r.set('name', '夢(mèng)想橡皮擦') print(r)
可以在可視化工具中查看到數(shù)據(jù)已經(jīng)寫(xiě)入。
獲取鍵值
r.get('name')
基礎(chǔ)準(zhǔn)備好,接下來(lái)就將 JSON 文件一次性的寫(xiě)入到 redis 中。
操作 JSON 文件寫(xiě)入 redis
首先使用 json.load() 方法讀取 JSON 文件,首先看一下 JSON 文件內(nèi)容。
JSON 最外層是一個(gè)列表,其中每一個(gè)元素都是對(duì)象,我們需要將每個(gè)對(duì)象都插入到 redis 中,形成 使 Redis 的哈希表。
完整代碼如下所示:
import redis import json r = redis.Redis(host='localhost', port=6379, db=15) with open('travel.json', 'r',encoding='utf-8') as file: data = json.load(file) for item in data: r.lpush('travel', json.dumps(item))
先看一下插入之后的結(jié)果。
上述代碼是將 JSON 文件中的每一項(xiàng)都轉(zhuǎn)換為字符串,然后以 lpush 方式插入到隊(duì)列的左側(cè),也可以使用 rpush 進(jìn)行插入。
如果希望以鍵值對(duì)形式進(jìn)行插入,需要使用 hset() 方法,參考代碼如下所示。
import redis import json r = redis.Redis(host='localhost', port=6379, db=15) with open('travel.json', 'r',encoding='utf-8') as file: data = json.load(file) for index,item in enumerate(data): r.hset('travel', index, json.dumps(item))
可以看到此時(shí) redis 中存儲(chǔ)了 key 和 value 。
r.hset(name, key, value) 方法是 Redis 哈希表命令之一,用于將指定的鍵和值添加到 Redis 哈希表中。
- 參數(shù)說(shuō)明如下:
- name:哈希表的名稱(chēng)。
- key:要添加的鍵。
- value:要添加的值。
它返回一個(gè)整數(shù),表示添加的鍵值對(duì)是否是該哈希表的新鍵值對(duì)。
如果返回 1,表示新鍵值對(duì)已添加;
如果返回 0,表示鍵已經(jīng)存在,并且值已被更新。
?文章來(lái)源:http://www.zghlxwxcb.cn/news/detail-461077.html
點(diǎn)擊關(guān)注,第一時(shí)間了解華為云新鮮技術(shù)~文章來(lái)源地址http://www.zghlxwxcb.cn/news/detail-461077.html
到了這里,關(guān)于如何通過(guò)Python將JSON格式文件導(dǎo)入redis?的文章就介紹完了。如果您還想了解更多內(nèi)容,請(qǐng)?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!