> 데이터 베이스 > Redis > Redis의 List 작업에 대한 자세한 설명

Redis의 List 작업에 대한 자세한 설명

藏色散人
풀어 주다: 2020-08-25 12:25:39
앞으로
5942명이 탐색했습니다.

다음은 Redis튜토리얼 칼럼에서 Redis의 List 작업에 대한 자세한 설명입니다. 도움이 필요한 친구들에게 도움이 되길 바랍니다!

Redis의 List 작업에 대한 자세한 설명

List 작업은 Redis의 List가 하나의 List에 해당하는 하나의 이름에 따라 메모리에 저장됩니다. 그림에 표시된 대로:

1, lpush(이름, 값)


# 在name对应的list中添加元素,每个新的元素都添加到列表的最左边
 # 如:
    # r.lpush('oo', 11,22,33)
    # 保存顺序为: 33,22,11
 # 扩展:
    # rpush(name, values) 表示从右向左操作
로그인 후 복사

2, lpushx(이름, 값)


# 在name对应的list中添加元素,只有name已经存在时,值添加到列表的最左边
 # 更多:
    # rpushx(name, value) 表示从右向左操作
로그인 후 복사

3 .llen (name) (

# name对应的list元素的个数
로그인 후 복사


4, linsert (이름, 여기서, refvalue, value))

# 在name对应的列表的某一个值前或后插入一个新值
 # 参数:
    # name,redis的name
    # where,BEFORE或AFTER(小写也可以)
    # refvalue,标杆值,即:在它前后插入数据(如果存在多个标杆值,以找到的第一个为准)
    # value,要插入的数据
로그인 후 복사


5r.lset (이름, 인덱스, 값)

# 对name对应的list中的某一个索引位置重新赋值
 # 参数:
    # name,redis的name
    # index,list的索引位置
    # value,要设置的值
로그인 후 복사


6, r.lrem(이름, 값, 숫자)

# 在name对应的list中删除指定的值
 # 参数:
    # name,redis的name
    # value,要删除的值
    # num,  num=0,删除列表中所有的指定值;
           # num=2,从前到后,删除2个;
           # num=-2,从后向前,删除2个
로그인 후 복사


7, lpop(이름)

# 在name对应的列表的左侧获取第一个元素并在列表中移除,返回值则是第一个元素
 # 更多:
    # rpop(name) 表示从右向左操作
로그인 후 복사


8, l 인덱스 (이름, 색인)

# 在name对应的列表中根据索引获取列表元素
로그인 후 복사


9、lrange(이름, 시작, 끝)

# 在name对应的列表分片获取数据# 参数:
    # name,redis的name
    # start,索引的起始位置
    # end,索引结束位置  print(re.lrange('aa',0,re.llen('aa')))
로그인 후 복사

10、
ltrim(이름, 시작, 끝)

# 在name对应的列表中移除没有在start-end索引之间的值# 参数:
    # name,redis的name
    # start,索引的起始位置
    # end,索引结束位置(大于列表长度,则代表不移除任何)
로그인 후 복사


11, rpoplpush(src, dst)

# 从一个列表取出最右边的元素,同时将其添加至另一个列表的最左边# 参数:
    # src,要取数据的列表的name
    # dst,要添加数据的列表的name
로그인 후 복사


11, blpop(키, 시간 초과)

# 将多个列表排列,按照从左到右去pop对应列表的元素
 # 参数:
    # keys,redis的name的集合
    # timeout,超时时间,当元素所有列表的元素获取完之后,阻塞等待列表内有数据的时间(秒), 0 表示永远阻塞
 # 更多:
    # r.brpop(keys, timeout),从右向左获取数据爬虫实现简单分布式:多个url放到列表里,往里不停放URL,程序循环取值,但是只能一台机器运行取值,可以把url放到redis中,多台机器从redis中取值,爬取数据,实现简单分布式
로그인 후 복사


12, brpoplpush(src, d st , 시간 초과=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)
로그인 후 복사

위 내용은 Redis의 List 작업에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:cnblogs.com
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿