下面由redis教程欄目給大家介紹redis之list操作詳解,希望對需要的朋友有所幫助!
List操作,redis中的List在在內存中按照一個name對應一個List來存儲。如圖:
1、lpush(name,values)#?在name對應的list中添加元素,每個新的元素都添加到列表的最左邊 ?#?如: ????#?r.lpush(‘oo’,?11,22,33) ????#?保存順序為:?33,22,11 ?#?擴展: ????#?rpush(name,?values)?表示從右向左操作
2、lpushx(name,value)
# 在name對應的list中添加元素,只有name已經存在時,值添加到列表的最左邊 # 更多: # rpushx(name, value) 表示從右向左操作
3、llen(name)
# name對應的list元素的個數
4、linsert(name, where, refvalue, value))
# 在name對應的列表的某一個值前或后插入一個新值 # 參數: # name,redis的name # where,BEFORE或AFTER(小寫也可以) # refvalue,標桿值,即:在它前后插入數據(如果存在多個標桿值,以找到的第一個為準) # value,要插入的數據
5r.lset(name, index, value)
# 對name對應的list中的某一個索引位置重新賦值 # 參數: # name,redis的name # index,list的索引位置 # value,要設置的值
6、r.lrem(name, value, num)
# 在name對應的list中刪除指定的值 # 參數: # name,redis的name # value,要刪除的值 # num, num=0,刪除列表中所有的指定值; # num=2,從前到后,刪除2個; # num=-2,從后向前,刪除2個
7、lpop(name)
# 在name對應的列表的左側獲取第一個元素并在列表中移除,返回值則是第一個元素 # 更多: # rpop(name) 表示從右向左操作
8、lindex(name, index)
# 在name對應的列表中根據索引獲取列表元素
9、lrange(name, start, end)
# 在name對應的列表分片獲取數據# 參數: # name,redis的name # start,索引的起始位置 # end,索引結束位置 print(re.lrange('aa',0,re.llen('aa')))
10、ltrim(name, start, end)
# 在name對應的列表中移除沒有在start-end索引之間的值# 參數: # name,redis的name # start,索引的起始位置 # end,索引結束位置(大于列表長度,則代表不移除任何)
11、rpoplpush(src, dst)
# 從一個列表取出最右邊的元素,同時將其添加至另一個列表的最左邊# 參數: # src,要取數據的列表的name # dst,要添加數據的列表的name
11、blpop(keys, timeout)
# 將多個列表排列,按照從左到右去pop對應列表的元素 # 參數: # keys,redis的name的集合 # timeout,超時時間,當元素所有列表的元素獲取完之后,阻塞等待列表內有數據的時間(秒), 0 表示永遠阻塞 # 更多: # r.brpop(keys, timeout),從右向左獲取數據爬蟲實現簡單分布式:多個url放到列表里,往里不停放URL,程序循環取值,但是只能一臺機器運行取值,可以把url放到redis中,多臺機器從redis中取值,爬取數據,實現簡單分布式
12、brpoplpush(src, dst, timeout=0)
# 從一個列表的右側移除一個元素并將其添加到另一個列表的左側 # 參數: # src,取出并要移除元素的列表對應的name # dst,要插入元素的列表對應的name # timeout,當src對應的列表中沒有數據時,阻塞等待其有數據的超時時間(秒),0 表示永遠阻塞
13、自定義增量迭代
# 由于redis類庫中沒有提供對列表元素的增量迭代,如果想要循環name對應的列表的所有元素,那么就需要: # 1、獲取name對應的所有列表 # 2、循環列表# 但是,如果列表非常大,那么就有可能在第一步時就將程序的內容撐爆,所有有必要自定義一個增量迭代的功能: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)
? 版權聲明
文章版權歸作者所有,未經允許請勿轉載。
THE END
喜歡就支持一下吧
相關推薦