您好,登錄后才能下訂單哦!
小編給大家分享一下redis之List操作的案例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
List操作,redis中的List在在內(nèi)存中按照一個name對應(yīng)一個List來存儲。如圖:
1、lpush(name,values)
# 在name對應(yīng)的list中添加元素,每個新的元素都添加到列表的最左邊 # 如: # r.lpush('oo', 11,22,33) # 保存順序?yàn)? 33,22,11 # 擴(kuò)展: # rpush(name, values) 表示從右向左操作
2、lpushx(name,value)
# 在name對應(yīng)的list中添加元素,只有name已經(jīng)存在時,值添加到列表的最左邊 # 更多: # rpushx(name, value) 表示從右向左操作
3、llen(name)
# name對應(yīng)的list元素的個數(shù)
4、linsert(name, where, refvalue, value))
# 在name對應(yīng)的列表的某一個值前或后插入一個新值 # 參數(shù): # name,redis的name # where,BEFORE或AFTER(小寫也可以) # refvalue,標(biāo)桿值,即:在它前后插入數(shù)據(jù)(如果存在多個標(biāo)桿值,以找到的第一個為準(zhǔn)) # value,要插入的數(shù)據(jù)
5\r.lset(name, index, value)
# 對name對應(yīng)的list中的某一個索引位置重新賦值 # 參數(shù): # name,redis的name # index,list的索引位置 # value,要設(shè)置的值
6、r.lrem(name, value, num)
# 在name對應(yīng)的list中刪除指定的值 # 參數(shù): # name,redis的name # value,要刪除的值 # num, num=0,刪除列表中所有的指定值; # num=2,從前到后,刪除2個; # num=-2,從后向前,刪除2個
7、lpop(name)
# 在name對應(yīng)的列表的左側(cè)獲取第一個元素并在列表中移除,返回值則是第一個元素 # 更多: # rpop(name) 表示從右向左操作
8、lindex(name, index)
# 在name對應(yīng)的列表中根據(jù)索引獲取列表元素
9、lrange(name, start, end)
# 在name對應(yīng)的列表分片獲取數(shù)據(jù)# 參數(shù): # name,redis的name # start,索引的起始位置 # end,索引結(jié)束位置 print(re.lrange('aa',0,re.llen('aa')))
10、ltrim(name, start, end)
# 在name對應(yīng)的列表中移除沒有在start-end索引之間的值# 參數(shù): # name,redis的name # start,索引的起始位置 # end,索引結(jié)束位置(大于列表長度,則代表不移除任何)
11、rpoplpush(src, dst)
# 從一個列表取出最右邊的元素,同時將其添加至另一個列表的最左邊# 參數(shù): # src,要取數(shù)據(jù)的列表的name # dst,要添加數(shù)據(jù)的列表的name
11、blpop(keys, timeout)
# 將多個列表排列,按照從左到右去pop對應(yīng)列表的元素 # 參數(shù): # keys,redis的name的集合 # timeout,超時時間,當(dāng)元素所有列表的元素獲取完之后,阻塞等待列表內(nèi)有數(shù)據(jù)的時間(秒), 0 表示永遠(yuǎn)阻塞 # 更多: # r.brpop(keys, timeout),從右向左獲取數(shù)據(jù)爬蟲實(shí)現(xiàn)簡單分布式:多個url放到列表里,往里不停放URL,程序循環(huán)取值,但是只能一臺機(jī)器運(yùn)行取值,可以把url放到redis中,多臺機(jī)器從redis中取值,爬取數(shù)據(jù),實(shí)現(xiàn)簡單分布式
12、brpoplpush(src, dst, timeout=0)
# 從一個列表的右側(cè)移除一個元素并將其添加到另一個列表的左側(cè) # 參數(shù): # src,取出并要移除元素的列表對應(yīng)的name # dst,要插入元素的列表對應(yīng)的name # timeout,當(dāng)src對應(yīng)的列表中沒有數(shù)據(jù)時,阻塞等待其有數(shù)據(jù)的超時時間(秒),0 表示永遠(yuǎn)阻塞
13、自定義增量迭代
# 由于redis類庫中沒有提供對列表元素的增量迭代,如果想要循環(huán)name對應(yīng)的列表的所有元素,那么就需要: # 1、獲取name對應(yīng)的所有列表 # 2、循環(huán)列表# 但是,如果列表非常大,那么就有可能在第一步時就將程序的內(nèi)容撐爆,所有有必要自定義一個增量迭代的功能:import redis conn=redis.Redis(host='127.0.0.1',port=6379)# conn.lpush('test',*[1,2,3,4,45,5,6,7,7,8,43,5,6,768,89,9,65,4,23,54,6757,8,68])# conn.flushall()def scan_list(name,count=2): index=0 while True: data_list=conn.lrange(name,index,count+index-1) if not data_list: return index+=count for item in data_list: yield itemprint(conn.lrange('test',0,100))for item in scan_list('test',5): print('---') print(item)
以上是redis之List操作的案例分析的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。