這篇文章運用簡單易懂的例子給大家介紹使用redis存儲list的方法,代碼非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
在召陵等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供成都網(wǎng)站設(shè)計、成都網(wǎng)站制作、外貿(mào)網(wǎng)站建設(shè) 網(wǎng)站設(shè)計制作按需定制設(shè)計,公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),品牌網(wǎng)站設(shè)計,營銷型網(wǎng)站建設(shè),成都外貿(mào)網(wǎng)站建設(shè),召陵網(wǎng)站建設(shè)費用合理。在工作中遇到了一個問題就是,因為業(yè)務(wù)需求需要做redis加速,那么存放在redis的list列表如何才能完整的存進去,再完整的取出來呢?
如果使用redis的list存儲方法,將list = [1,2,3,4]列表中的元素一個一個遍歷取出,然后用lpush的方法將元素一個一個存進去,到最后你用完整的了lrange('name',0,-1)取出,你會發(fā)現(xiàn)取出的list變成了一個str, 例如(list = '[1,2,3,4]'),這樣處理起來很麻煩。
經(jīng)過不斷的嘗試,發(fā)現(xiàn)了一個比較好用的庫pickle.
pikle的優(yōu)點是:序列化過程將文本信息轉(zhuǎn)變?yōu)槎M制數(shù)據(jù)流。這樣就信息就容易存儲在硬盤之中,當(dāng)需要讀取文件的時候,從硬盤中讀取數(shù)據(jù),然后再將其反序列化便可以得到原始的數(shù)據(jù)。
在Python程序運行中得到了一些字符串、列表、字典等數(shù)據(jù),想要長久的保存下來,方便以后使用,而不是簡單的放入內(nèi)存中關(guān)機斷電就丟失數(shù)據(jù)。
python模塊大全中的Pickle模塊就派上用場了,它可以將對象轉(zhuǎn)換為一種可以傳輸或存儲的格式。這樣保證存儲和取出的數(shù)據(jù)的完整性。
from redis import StrictRedis # 選取一個默認的redis的db倉庫 db = StrictRedis(host='localhost', port=6379, db=0,decode_responses=True) #導(dǎo)入pickle包 import pickle list = [1,2,3,4] # pickle 封裝list new_list = pickle.dumps(list) # redis中存儲數(shù)據(jù),設(shè)置過期時間 db.setx('list',3600,new_list) result = db.get('list') get_list = pickle.loads(result) print(get_list) # get_list = [1,2,3,4]
經(jīng)過pickle這樣處理后,你會發(fā)現(xiàn)取出的list好用多了。再也不用為數(shù)據(jù)轉(zhuǎn)換煞費苦心了,而且同樣的也可以處理json等數(shù)據(jù)類型的數(shù)據(jù)。
關(guān)于使用redis存儲list的方法就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。