溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

redis之List操作的案例分析

發(fā)布時間:2020-08-26 09:41:08 來源:億速云 閱讀:188 作者:小新 欄目:關(guān)系型數(shù)據(jù)庫

小編給大家分享一下redis之List操作的案例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

List操作,redis中的List在在內(nèi)存中按照一個name對應(yīng)一個List來存儲。如圖:

redis之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è)資訊頻道!

向AI問一下細(xì)節(jié)

免責(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)容。

AI