redis 列表(list)函数

列表(list)函数

lPush 命令/方法/函数
Description

Adds the string value to the head (left) of the list. Creates the list if the key didn‘t exist. If the key exists and is not a list, FALSE is returned.

添加一个字符串值到LIST容器的顶部(左侧),如果KEY不存在,曾创建一个LIST容器,如果KEY存在并且不是一个LIST容器,那么返回FLASE。

Parameters

key

value String, value to push in key

Return value

LONG The new length of the list in case of success, FALSE in case of Failure.

返回LIST容器最新的长度,如果ADD成功。失败则返回FALSE。

Examples

$redis->delete(‘key1‘);

$redis->lPush(‘key1‘, ‘C‘); // returns 1

$redis->lPush(‘key1‘, ‘B‘); // returns 2

$redis->lPush(‘key1‘, ‘A‘); // returns 3

/* key1 now points to the following list: [ ‘A‘, ‘B‘, ‘C‘ ] */
rPush 命令/方法/函数
Description

Adds the string value to the tail (right) of the list. Creates the list if the key didn‘t exist. If the key exists and is not a list, FALSE is returned.

添加一个字符串值到LIST容器的底部(右侧),如果KEY不存在,曾创建一个LIST容器,如果KEY存在并且不是一个LIST容器,那么返回FLASE。

Parameters

key

value String, value to push in key

Return value

LONG The new length of the list in case of success, FALSE in case of Failure.

返回LIST容器最新的长度,如果ADD成功。失败则返回FALSE。

Examples

$redis->delete(‘key1‘);

$redis->rPush(‘key1‘, ‘A‘); // returns 1

$redis->rPush(‘key1‘, ‘B‘); // returns 2

$redis->rPush(‘key1‘, ‘C‘); // returns 3

/* key1 now points to the following list: [ ‘A‘, ‘B‘, ‘C‘ ] */
lPushx 命令/方法/函数
Description

Adds the string value to the head (left) of the list if the list exists.

添加一个VALUE到LIST容器的顶部(左侧)如果这个LIST存在的话。

Parameters

key

value String, value to push in key

Return value

LONG The new length of the list in case of success, FALSE in case of Failure.

如果ADD成功, 返回LIST容器最新的长度。失败则返回FALSE。

Examples

$redis->delete(‘key1‘);

$redis->lPushx(‘key1‘, ‘A‘); // returns 0

$redis->lPush(‘key1‘, ‘A‘); // returns 1

$redis->lPushx(‘key1‘, ‘B‘); // returns 2

$redis->lPushx(‘key1‘, ‘C‘); // returns 3

/* key1 now points to the following list: [ ‘A‘, ‘B‘, ‘C‘ ] */
rPushx 命令/方法/函数
Description

Adds the string value to the tail (right) of the list if the ist exists. FALSE in case of Failure.

添加一个VALUE到LIST容器的底部(右侧)如果这个LIST存在的话。

Parameters

key

value String, value to push in key

Return value

LONG The new length of the list in case of success, FALSE in case of Failure.

如果ADD成功, 返回LIST容器最新的长度。失败则返回FALSE。

Examples

$redis->delete(‘key1‘);

$redis->rPushx(‘key1‘, ‘A‘); // returns 0

$redis->rPush(‘key1‘, ‘A‘); // returns 1

$redis->rPushx(‘key1‘, ‘B‘); // returns 2

$redis->rPushx(‘key1‘, ‘C‘); // returns 3

/* key1 now points to the following list: [ ‘A‘, ‘B‘, ‘C‘ ] */
lPop 命令/方法/函数
Description

Return and remove the first element of the list.

返回LIST顶部(左侧)的VALUE,并且从LIST中把该VALUE弹出。

Parameters

key

Return value

STRING if command executed successfully BOOL FALSE in case of failure (empty list)

取得VALUE成功,返回TURE。如果是一个空LIST则返回FLASE。

Example

$redis->rPush(‘key1‘, ‘A‘);

$redis->rPush(‘key1‘, ‘B‘);

$redis->rPush(‘key1‘, ‘C‘); /* key1 => [ ‘A‘, ‘B‘, ‘C‘ ] */

$redis->lPop(‘key1‘); /* key1 => [ ‘B‘, ‘C‘ ] */
rPop 命令/方法/函数
Description

Returns and removes the last element of the list.

返回LIST底部(右侧)的VALUE,并且从LIST中把该VALUE弹出。

Parameters

key

Return value

STRING if command executed successfully BOOL FALSE in case of failure (empty list)

取得VALUE成功,返回TURE。如果是一个空LIST则返回FLASE。

Example

$redis->rPush(‘key1‘, ‘A‘);

$redis->rPush(‘key1‘, ‘B‘);

$redis->rPush(‘key1‘, ‘C‘); /* key1 => [ ‘A‘, ‘B‘, ‘C‘ ] */

$redis->rPop(‘key1‘); /* key1 => [ ‘A‘, ‘B‘ ] */
blPop, brPop 命令/方法/函数
Description

Is a blocking lPop(rPop) primitive. If at least one of the lists contains at least one element, the element will be popped from the head of the list and returned to the caller. Il all the list identified by the keys passed in arguments are empty, blPop will block during the specified timeout until an element is pushed to one of those lists. This element will be popped.

lpop命令的block版本即阻塞版本。如果LIST容器中有VAULE,将会返回ARRAY(‘listName‘‘element‘)。如果TIMEOUT参数为空,那么如果LIST为空,blPop或者brPop将或结束调用。如果设置了timeout参数,blPop或者brPop将被挂起暂停运行TIMEOUT参数的时间,在此期间如果LIST被PUSH了元素,将在TIMEOUT时间结束后,被POP出来。

Parameters

ARRAY Array containing the keys of the lists INTEGER Timeout Or STRING Key1 STRING Key2 STRING Key3 ... STRING KeynINTEGER Timeout

Return value

ARRAY array(‘listName‘, ‘element‘)

Example

/* Non blocking feature */

$redis->lPush(‘key1‘, ‘A‘);

$redis->delete(‘key2‘);

$redis->blPop(‘key1‘, ‘key2‘, 10); /* array(‘key1‘, ‘A‘) */

/* OR */

$redis->blPop(array(‘key1‘, ‘key2‘), 10); /* array(‘key1‘, ‘A‘) */

$redis->brPop(‘key1‘, ‘key2‘, 10); /* array(‘key1‘, ‘A‘) */

/* OR */

$redis->brPop(array(‘key1‘, ‘key2‘), 10); /* array(‘key1‘, ‘A‘) */

/* Blocking feature */

/* process 1 */

$redis->delete(‘key1‘);

$redis->blPop(‘key1‘, 10);

/* blocking for 10 seconds */

/* process 2 */

$redis->lPush(‘key1‘, ‘A‘);

/* process 1 */

/* array(‘key1‘, ‘A‘) is returned*/
lSize 命令/方法/函数
Returns the size of a list identified by Key. If the list didn‘t exist or is empty, the command returns 0. If the data type identified by Key is not a list, the command return FALSE.

根据KEY返回该KEY代表的LIST的长度,如果这个LIST不存在或者为空,那么ISIZE返回0,如果指定的KEY的数据类型不是LIST或者不为空,那么返回FALSE。所以在这里多说一句,当用ISize返回判断值的时候,===就有用处了,这里FLASE和0是两个概念了。

Parameters

Key

Return value

LONG The size of the list identified by Key exists.

如果KEY存在并且为LIST且有元素,那么返回KEY的长度,为空或者不存在返回0。

BOOL FALSE if the data type identified by Key is not list

如果KEY的数据类型不为空或者LIST,则返回FALSE。

Example

$redis->rPush(‘key1‘, ‘A‘);

$redis->rPush(‘key1‘, ‘B‘);

$redis->rPush(‘key1‘, ‘C‘); /* key1 => [ ‘A‘, ‘B‘, ‘C‘ ] */

$redis->lSize(‘key1‘);/* 3 */

$redis->rPop(‘key1‘); 

$redis->lSize(‘key1‘);/* 2 */
lGet 命令/方法/函数
Description

Return the specified element of the list stored at the specified key. 0 the first element, 1 the second ... -1 the last element, -2 the penultimate ... Return FALSE in case of a bad index or a key that doesn‘t point to a list.

根据索引值返回指定KEY LIST中的元素。0为第一个元素,1为第二个元素。-1为倒数第一个元素,-2为倒数第二个元素。如果指定了一个不存在的索引值,则返回FLASE。

Parameters

key index

Return value

String the element at this index

Bool FALSE if the key identifies a non-string data type, or no value corresponds to this index in the list Key.

Example

$redis->rPush(‘key1‘, ‘A‘);

$redis->rPush(‘key1‘, ‘B‘);

$redis->rPush(‘key1‘, ‘C‘); /* key1 => [ ‘A‘, ‘B‘, ‘C‘ ] */

$redis->lGet(‘key1‘, 0); /* ‘A‘ */

$redis->lGet(‘key1‘, -1); /* ‘C‘ */

$redis->lGet(‘key1‘, 10); /* `FALSE` */
lSet 命令/方法/函数
Set the list at index with the new value.

根据索引值设置新的VAULE

Parameters

key index value

Return value

BOOL TRUE if the new value is setted. FALSE if the index is out of range, or data type identified by key is not a list.

如果设置成功返回TURE,如果KEY所指向的不是LIST,或者索引值超出LIST本身的长度范围,则返回flase。

Iset函数更像是UPDATE或者EDIT的概念,而不是INSERT或者ADD的概念,顾只能在LIST本身的长度范围内,而不能超出。

Example

$redis->rPush(‘key1‘, ‘A‘);

$redis->rPush(‘key1‘, ‘B‘);

$redis->rPush(‘key1‘, ‘C‘); /* key1 => [ ‘A‘, ‘B‘, ‘C‘ ] */

$redis->lGet(‘key1‘, 0); /* ‘A‘ */

$redis->lSet(‘key1‘, 0, ‘X‘);

$redis->lGet(‘key1‘, 0); /* ‘X‘ */ 
lRange 命令/方法/函数
Returns the specified elements of the list stored at the specified key in the range [start, end]. start and stop are interpretated as indices: 0 the first element, 1 the second ... -1 the last element, -2 the penultimate ...

取得指定索引值范围内的所有元素。

Parameters

key start end

Return value

Array containing the values in specified range.

Example

$redis->rPush(‘key1‘, ‘A‘);

$redis->rPush(‘key1‘, ‘B‘);

$redis->rPush(‘key1‘, ‘C‘);

$redis->lRange(‘key1‘, 0, -1); /* array(‘A‘, ‘B‘, ‘C‘) */
lTrim 命令/方法/函数
Trims an existing list so that it will contain only a specified range of elements.

它将截取LIST中指定范围内的元素组成一个新的LIST并指向KEY。简短解说就是截取LIST。

这个可不是JS,或者PHP中清空空格的意思。

Parameters

key start stop

Return value

Array

Bool return FALSE if the key identify a non-list value.

Example

$redis->rPush(‘key1‘, ‘A‘);

$redis->rPush(‘key1‘, ‘B‘);

$redis->rPush(‘key1‘, ‘C‘);

$redis->lRange(‘key1‘, 0, -1); /* array(‘A‘, ‘B‘, ‘C‘) */

$redis->lTrim(‘key1‘, 0, 1);

$redis->lRange(‘key1‘, 0, -1); /* array(‘A‘, ‘B‘) */
lRem 命令/方法/函数
Removes the first count occurences of the value element from the list. If count is zero, all the matching elements are removed. If count is negative, elements are removed from tail to head.

IRem,IRemove函数,首先要去判断count参数,如果count参数为0,那么所有符合删除条件的元素都将被移除。如果count参数为整数,将从左至右删除count个符合条件的元素,如果为负数则从右至左删除count个符合条件的元素。

Note: The argument order is not the same as in the Redis documentation. This difference is kept for compatibility reasons.

函数参数的顺序不一定要一致,这样做是为了保持兼容性。

Parameters

key

value

count

Return value

LONG the number of elements to remove

BOOL FALSE if the value identified by key is not a list.

Example

$redis->lPush(‘key1‘, ‘A‘);

$redis->lPush(‘key1‘, ‘B‘);

$redis->lPush(‘key1‘, ‘C‘); 

$redis->lPush(‘key1‘, ‘A‘); 

$redis->lPush(‘key1‘, ‘A‘); 

$redis->lRange(‘key1‘, 0, -1); /* array(‘A‘, ‘A‘, ‘C‘, ‘B‘, ‘A‘) */

$redis->lRem(‘key1‘, ‘A‘, 2); /* 2 */

$redis->lRange(‘key1‘, 0, -1); /* array(‘C‘, ‘B‘, ‘A‘) */
lInsert 命令/方法/函数
Insert value in the list before or after the pivot value. the parameter options specify the position of the insert (before or after). If the list didn‘t exists, or the pivot didn‘t exists, the value is not inserted.

在指定LIST中的指定中枢VALUE的左侧或者右侧插入VALUE。如果这个LIST不存在,或者这个pivot(key position)不存在,那么这个VALUE不会被插入。

Parameters

key position Redis::BEFORE | Redis::AFTER pivot value

Return value

The number of the elements in the list, -1 if the pivot didn‘t exists.

Example

$redis->delete(‘key1‘);

$redis->lInsert(‘key1‘, Redis::AFTER, ‘A‘, ‘X‘); /* 0 */

$redis->lPush(‘key1‘, ‘A‘);

$redis->lPush(‘key1‘, ‘B‘);

$redis->lPush(‘key1‘, ‘C‘);

$redis->lInsert(‘key1‘, Redis::BEFORE, ‘C‘, ‘X‘); /* 4 */

$redis->lRange(‘key1‘, 0, -1); /* array(‘A‘, ‘B‘, ‘X‘, ‘C‘) */

$redis->lInsert(‘key1‘, Redis::AFTER, ‘C‘, ‘Y‘); /* 5 */

$redis->lRange(‘key1‘, 0, -1); /* array(‘A‘, ‘B‘, ‘X‘, ‘C‘, ‘Y‘) */

$redis->lInsert(‘key1‘, Redis::AFTER, ‘W‘, ‘value‘); /* -1 */
rpoplpush 命令/方法/函数
Pops a value from the tail of a list, and pushes it to the front of another list. Also return this value.

从源LIST的最后弹出一个元素,并且把这个元素从目标LIST的顶部(左侧)压入目标LIST。

Parameters

Key: srckey

Key: dstkey

Return value

STRING The element that was moved in case of success, FALSE in case of failure.

Example

$redis->delete(‘x‘, ‘y‘);

$redis->lPush(‘x‘, ‘abc‘);

$redis->lPush(‘x‘, ‘def‘);

$redis->lPush(‘y‘, ‘123‘);

$redis->lPush(‘y‘, ‘456‘);

// move the last of x to the front of y.

var_dump($redis->rpoplpush(‘x‘, ‘y‘));

var_dump($redis->lRange(‘x‘, 0, -1));

var_dump($redis->lRange(‘y‘, 0, -1));

Output:

string(3) "abc"

array(1) {

  [0]=>

  string(3) "def"

}

array(3) {

  [0]=>

  string(3) "abc"

  [1]=>

  string(3) "456"

  [2]=>

  string(3) "123"

}

原文地址:https://www.cnblogs.com/xiong63/p/9878782.html

时间: 2024-10-12 08:07:41

redis 列表(list)函数的相关文章

redis 列表

Redis 列表(List) Redis列表是简单的字符串列表,按照插入顺序排序.你可以添加一个元素导列表的头部(左边)或者尾部(右边) 一个列表最多可以包含 232 - 1 个元素 (4294967295, 每个列表超过40亿个元素). 实例 redis 127.0.0.1:6379> LPUSH runoobkey redis (integer) 1 redis 127.0.0.1:6379> LPUSH runoobkey mongodb (integer) 2 redis 127.0.

Redis 列表(List)

Redis列表是简单的字符串列表,按照插入顺序排序.你可以添加一个元素导列表的头部(左边)或者尾部(右边) 一个列表最多可以包含 232 - 1 个元素 (4294967295, 每个列表超过40亿个元素). 实例 redis 127.0.0.1:6379> LPUSH w3ckey redis (integer) 1 redis 127.0.0.1:6379> LPUSH w3ckey mongodb (integer) 2 redis 127.0.0.1:6379> LPUSH w3

Effective JavaScript Item 22 使用arguments来创建接受可变参数列表的函数

本系列作为Effective JavaScript的读书笔记. 在Item 21中,介绍了结合apply方法实现的可变参数列表函数average,它实际上只声明了一个数组作为参数,但是利用apply方法,实际上可以接受若干元素作为参数: function averageOfArray(a) { for (var i = 0, sum = 0, n = a.length; i < n; i++) { sum += a[i]; } return sum / n; } averageOfArray.a

Redis列表

Redis列表是简单的字符串列表,排序插入顺序.您可以在头部或列表的尾部Redis的列表添加元素. 列表的最大长度为232 - 1 (每个列表超过4十亿元素4294967295)元素. 例子 redis 127.0.0.1:6379> LPUSH tutorials redis (integer) 1 redis 127.0.0.1:6379> LPUSH tutorials mongodb (integer) 2 redis 127.0.0.1:6379> LPUSH tutorial

Python学习系列(四)(列表及其函数)

Python学习系列(四)(列表及其函数) Python学习系列(一)(基础入门) Python学习系列(二)(基础知识) Python学习系列(三)(字符串) 一.基本概念 1,列表是什么? 一种序列型数据类型,一有序数据集合用逗号间隔用方括号括起来. 2,几种访问形式 1)索引访问,语法结构:list_name[index].注意,列表的索引值从0开始.例如: 1 >>> li=[1,2,3,4,5] 2 >>> print li[2],li[0] 3 3 1 删除

Redis列表(List)

Redis列表是简单的字符串列表,按照插入顺序排序.你可以添加一个元素到列表的头部(左边)或者尾部(右边) 一个列表最多可以包含 \(2^{32} - 1\) 个元素 (4294967295, 每个列表超过40亿个元素). 实例 redis 127.0.0.1:6379> LPUSH mylist redis (integer) 1 redis 127.0.0.1:6379> LPUSH mylist mongodb (integer) 2 redis 127.0.0.1:6379> L

由Redis的hGetAll函数所引发的一次服务宕机事件

昨晚通宵生产压测,终于算是将生产服务宕机的原因定位到了,心累.这篇博客,算作一个复盘和记录吧... 先来看看Redis的缓存淘汰算法思维导图: 说明:当实际占用的内存超过Redis配置的maxmemory时,Redis就会根据用户选择淘汰策略清除被选中的key. 业务场景:用户通过微信入口来访问一个页面: 测试场景:通过多线程模拟定量的并发来访问页面服务: 涉及架构:springsession+Redis集群,容器部署: 问题描述:固定并发数压测10分钟,压测开始后半小时,Redis连接数激增,

雷林鹏分享:Redis 列表(List)

Redis列表是简单的字符串列表,按照插入顺序排序.你可以添加一个元素到列表的头部(左边)或者尾部(右边) 一个列表最多可以包含 232 - 1 个元素 (4294967295, 每个列表超过40亿个元素). 实例 redis 127.0.0.1:6379> LPUSH coderctokey redis (integer) 1 redis 127.0.0.1:6379> LPUSH coderctokey mongodb (integer) 2 redis 127.0.0.1:6379>

列表反转函数

列表反转函数一: #!/user/bin/python # -*- coding: UTF-8 -*- def reverse(li): for i in range(0, len(li)/2): temp = li[i] li[i] = li[-i-1] li[-i-1] = temp l = [1, 2, 3, 4, 5] reverse(l) print(l) 列表反转函数二: def reverse(ListInput): RevList=[] for i in range (len(L