Python 分布式缓存之Reids数据类型操作详解


Posted in Python onJune 24, 2020

1、Redis API

1.安装redis模块

$ pip3.8 install redis

2.使用redis模块

import redis

# 连接redis的ip地址/主机名,port,password=None
r = redis.Redis(host="127.0.0.1",port=6379,password="gs123456")

3.redis连接池

redis-py使用connection pool来管理对一个redis server的所有连接,避免每次建立、释放连接的开销。默认,每个Redis实例都会维护一个自己的连接池。可以直接建立一个连接池,然后作为参数Redis,这样就可以实现多个Redis实例共享一个连接池

总之,当程序创建数据源实例时,系统会一次性创建多个数据库连接,并把这些数据库连接保存在连接池中,当程序需要进行数据库访问时,无需重新新建数据库连接,而是从连接池中取出一个空闲的数据库连接

import redis
# 创建连接池,将连接保存在连接池中
pool = redis.ConnectionPool(host="127.0.0.1",port=6379,password="gs123456",max_connections=10)

# 创建一个redis实例,并使用连接池"pool"
r = redis.Redis(connection_pool=pool)

2、String 操作

redis中的String在内存中按照一个name对应一个value来存储。如图:

Python 分布式缓存之Reids数据类型操作详解

1. set 为name设置值

# 在Redis中设置值,默认,不存在则创建,存在则修改
set(name, value, ex=None, px=None, nx=False, xx=False, keepttl=False)

name:设置键
value:设置值
ex:设置过期时间(秒级)
px:设置过期时间(毫秒)
nx:如果设置为True,则只有name不存在时,当前set操作才执行,同setnx(name, value)
xx:如果设置为True,则只有name存在时,当前set操作才执行

set用法:

r.set("name1","jack",ex=3600)
r.set("name2","xander",xx=36000)

setnx用法:

# 设置值,只有name不存在时,执行设置操作(添加)
setnx(name, value)

setex用法:

# 设置值,参数:time -->过期时间(数字秒 或 timedelta对象)
setex(name, value, time)

psetex用法:

# 设置值,参数:time_ms,过期时间(数字毫秒 或 timedelta对象)
psetex(name, time_ms, value)

2. get 获取name的值

# 根据key获取值
get(name)

r.get("foo")

3. mset 批量设置name的值:

mset(mapping)

data = {
  "k1":"v1",
  "k2":"v2",
}
r.mset(data)

4. Mget 批量获取name的值

# 批量获取值,根据多key获取多个值
mgets(mapping)

# 方法一
r.mget("k1","k2")

# 方法二
data = ["k1","k2"]
r.mget(data)

# 方法三
data = ("k1","k2")
r.mget(data)

5. getset 设置新值并获取原来的值

getset(name, value)

r.set("foo", "xoo")
ret = r.getset("foo", "yoo")
print(ret) # b'xoo'

6. append 为name原有值后追加内容

# key对应值的后面追加内容
append(key, value)

r.set("name","jack")
r.append("name","-m")
ret = r.get("name")
print(ret) # b'jack-m'

7. strlen 返回name的值字节长度:

# 返回字符串的长度,当name不存在时返回0
strlen(name)

r.set("name","jack-")
ret = r.strlen("name")
print(ret) # 5

8. incr 为name整数累加值

# 自增mount对应的值,当mount不存在时,则创建mount=amount,否则,则自增,amount为自增数(整数)
incr(name, amount=1)

r.incr('mount')
r.incr('mount')
r.incr('mount', amount=3)
ret = r.get('mount')
print(ret)		# b'5'

3、Hash 操作

hash表现形式上有些像pyhton中的dict,可以存储一组关联性较强的数据 ,redis中Hash在内存中的存储格式如下图:

Python 分布式缓存之Reids数据类型操作详解

1. hset 为name设置单个键值对

# name对应的hash中设置一个键值对(不存在,则创建;否则,修改)
hset(name, key, value)

name:设置name
key:name对应hash中的key(键)
value:name对应的hash中的value(值)

hset用法

# 一次只能设置一个键值对
r.hset("student-jack", "name", "Jack")

2 . hget 获取name单个键值对

# 根据name对应的hash中获取根据key获取value
hget(name,key)

ret = r.hget("student-jack", "name")
print(ret) // b'Jack'

3. hmset 为name设置多个键值对

# mapping中传入字典(不存在,则创建;否则,修改)
hmset(name, mapping):


data = {
  "name": "Jack",
  "age": 20,
  "gender": "M",
}
r.hmset("student-jack", mapping=data)

4. hmget 获取name多个键值对

# 根据name对应的hash中获取多个key的值
hmget(name, keys, *args)

name:指定name
keys:要获取key集合,如:['k1', 'k2', 'k3']
*args:要获取的key,如:k1,k2,k3


# 直接传入需要获取的键
ret = r.hmget("student-jack", "name", "age")
print(ret) # [b'Jack', b'20']

# 列表中指定需要获取的键
data = ["name", "age"]
ret = r.hmget("student-jack", data)
print(ret) # [b'Jack', b'20']

5. hgetall 获取name的键值对

# 根据name获取hash的所有值
hgetall(name)

ret = r.hgetall("student-jack")
print(ret)  # {b'name': b'Jack', b'age': b'20', b'gender': b'M'}

6、hlen 获取name中的键值对个数

# 根据name获取hash中键值对的总个数
hlen(name)

ret = r.hlen("student-jack")
print(ret) # 3 , 3个键值对

7. hkeys 获取name中键值对所有key

# 获取name里键值对的key
hkeys(name)

ret = r.hkeys('student-jack')
print(ret) # [b'name', b'age', b'gender']

8. hvals 获取name中键值对所有value

# 获取name里键值对的value
hvals(name)

ret = r.hvals('student-jack')
print(ret) # [b'Jack', b'20', b'M']

9. hkeys 检查name里的键值对是否有对应的key

# 根据name检查对应的hash是否存在当前传入的key
hexists(name, key)

# 返回布尔值
ret = r.hexists('student-jack', 'name')
print(ret)	# True

10. hincrby 从name里的键值对设置自增值

1.整数自增:

# 自增name对应的hash中的指定key的值,不存在则创建key=amount
hincrby(name, key, amount=1)

name:设置键
key:hash对应的key
amount:自增数(整数)


ret = r.hincrby('student-jack', 'age')
ret = r.hincrby('student-jack', 'age')
print(ret)		# 22

2.浮点自增

# 自增name对应的hash中的指定key的值,不存在则创建key=amount
hincrbyfloat(name, key, amount=1.0)

name:设置键
key:hash对应的key
amount:自增数(浮点数)

11. hdel 根据name从键值对中删除指定key

# 根据name将对应hash中指定的key键值对删除
hdel(name,*keys)


r.hdel("info",*("m-k1","m-k2"))

4、List 操作

List操作,redis中的List在内存中按照一个name对应一个List来存储。如图: 

Python 分布式缓存之Reids数据类型操作详解

1. lpush 为name添加元素,每个新的元素都添加到列表的最左边

# name对应的list中添加元素
lpush(name,values)


# 直接指定多个元素
r.lpush("names", "Jack", "Alex", "Eric")

# 将需要添加的元素添加到元组
data = ("Jack", "Alex", "Eric")
r.rpush("names", *data)

# 将需要添加的元素添加到列表
data = ["Jack", "Alex", "Eric"]
r.rpush("names", *data)

Note:列表类型中的值统称元素

2. rpush 为name添加元素,每个新的元素都添加到列表的最右边

# 同lpush,但每个新的元素都会添加到列表的最右边
rpush(name, values)

3. lpushx 为name添加元素,只有当name已存在时,将元素添加至列表最左边

lpushx(name,value)

4. rpushx 同上,将元素添加至列表最右边

rpushx(name, values)

5. llen 统计name中list的元素个数

# name对应的list元素的个数
llen(name)

ret = r.llen('names')
print(ret) # 3, 该list中有3个元素

6. linsert 为name中list的某一个值或后 插入一个新的值

# 在name对应的列表的某一个值前或后插入一个新值
linsert(name, where, refvalue, value)

name:设置name
where:BEFORE或AFTER
refvalue:标杆值,即:在它前后插入数据
value:要插入的数据


// 在Alex值前插入一个值(BEFORE表示:在...之前)
r.linsert('names', 'BEFORE', 'Jack', 'Jason')

// 在Jack后插入一个值(AFTER表示:在...之后)
r.linsert('names', 'AFTER', 'Jack', 'Xander')

7. lset 为name中list的某一个索引位置的元素重新赋值

# 对name对应的list中的某一个索引位置重新赋值
lset(name, index, value)

name:设置name
index:list的索引位置
value:要设置的值

// 将索引为1的元素修改为Gigi
r.lset('names', 1, 'Gigi')

8. lrem 移除name里对应list的元素

# 在name对应的list中删除指定的值
lrem(name, count, value)

name:设置name
value:要删除的值
count:count=0,删除列表中的指定值;
    count=2,从前到后,删除2个;
    count=-2,从后向前,删除2个

r.lrem('names', count=2, value='Xander')

9. lpop 从name里的list获取最左侧的第一个元素,并在列表中移除,返回值是则是第一个元素

lpop(name)

ret = r.lpop('names')
print(ret)		# b'Jason'

10. rpop 同上,从右侧获取第一个元素

rpop(name)

11. lindex 在name对应的列表 根据索引获取元素

# 在name对应的列表中根据索引获取列表元素
lindex(name, index)

ret = r.lindex('names', 0)
print(ret)	# b'Gigi'

12. ltrim 移除列表内没有在该索引之内的值(截断)

# 移除列表内没有在该索引之内的值
ltrim(name, start, end)

r.ltrim("names",0,2)

13. lrange 在name对应的列表 根据索引获取数据

# 在name对应的列表分片获取数据
lrange(name, start, end)

name:设置name
start:索引的起始位置
end:索引结束位置

// 先添加点元素
data = ['Jack', 'Eric', 'Koko', 'Jason', 'Alie']
r.rpush('names', *data)

// 获取列表所有元素
ret = r.lrange('names', 0, -1)
print(ret) # [b'Gigi', b'Alex', b'Jack', b'Eric', b'Koko', b'Jason', b'Alie']

// 获取列表索引2-5的元素(包含2和5,即 2 3 4 5)
ret = r.lrange('names', 2, 5)
print(ret)	# [b'Jack', b'Eric', b'Koko', b'Jason']

// 获取列表的最后一个元素
ret = r.lrange('names', -1, -1)
print(ret)  # [b'Alie']

到此这篇关于Python 分布式缓存之Reids数据类型操作详解的文章就介绍到这了,更多相关Python Reids数据类型操作内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
用Python操作字符串之rindex()方法的使用
May 19 Python
Python的网络编程库Gevent的安装及使用技巧
Jun 24 Python
python中利用await关键字如何等待Future对象完成详解
Sep 07 Python
Python3实现的Mysql数据库操作封装类
Jun 06 Python
python将字符串以utf-8格式保存在txt文件中的方法
Oct 30 Python
Python控制键盘鼠标pynput的详细用法
Jan 28 Python
浅谈Django中view对数据库的调用方法
Jul 18 Python
Flask教程之重定向与错误处理实例分析
Aug 01 Python
Python中pymysql 模块的使用详解
Aug 12 Python
Python3安装pip工具的详细步骤
Oct 14 Python
Django实现图片上传功能步骤解析
Apr 22 Python
python学习之使用Matplotlib画实时的动态折线图的示例代码
Feb 25 Python
PyTorch中model.zero_grad()和optimizer.zero_grad()用法
Jun 24 #Python
Pytorch实现将模型的所有参数的梯度清0
Jun 24 #Python
你需要学会的8个Python列表技巧
Jun 24 #Python
pytorch实现查看当前学习率
Jun 24 #Python
在pytorch中动态调整优化器的学习率方式
Jun 24 #Python
CentOS 7如何实现定时执行python脚本
Jun 24 #Python
python tkiner实现 一个小小的图片翻页功能的示例代码
Jun 24 #Python
You might like
通俗易懂的php防注入代码
2010/04/07 PHP
鸡肋的PHP单例模式应用详解
2013/06/03 PHP
php实现简单洗牌算法
2013/06/18 PHP
php中url传递中文字符,特殊危险字符的解决方法
2013/08/17 PHP
学习php中的正则表达式
2014/08/17 PHP
thinkphp隐藏index.php/home并允许访问其他模块的实现方法
2016/10/13 PHP
PHP mongodb操作类定义与用法示例【适合mongodb2.x和mongodb3.x】
2018/06/16 PHP
用javascript实现分割提取页面所需内容
2007/05/09 Javascript
Div Select挡住的解决办法
2008/08/07 Javascript
js模仿jquery的写法示例代码
2013/06/16 Javascript
iscroll.js滚动加载实例详解
2017/07/18 Javascript
微信小程序文章详情页面实现代码
2018/09/10 Javascript
小程序二次贝塞尔曲线实现购物车商品曲线飞入效果
2019/01/07 Javascript
利用JS如何获取form表单数据
2019/12/19 Javascript
Vue指令实现OutClick的示例
2020/11/16 Javascript
[57:55]EG vs Fnatic 2018国际邀请赛小组赛BO2 第一场 8.19
2018/08/21 DOTA
python3使用urllib示例取googletranslate(谷歌翻译)
2014/01/23 Python
python搭建虚拟环境的步骤详解
2016/09/27 Python
python递归打印某个目录的内容(实例讲解)
2017/08/30 Python
Windows 64位下python3安装nltk模块
2018/09/19 Python
Python Opencv 通过轨迹(跟踪)栏实现更改整张图像的背景颜色
2020/03/09 Python
Python实现获取当前目录下文件名代码详解
2020/03/10 Python
python如何更新包
2020/06/11 Python
css3实现书本翻页效果的示例代码
2021/03/08 HTML / CSS
html5 Canvas画图教程(2)—画直线与设置线条的样式如颜色/端点/交汇点
2013/01/09 HTML / CSS
耐克美国官网:Nike.com
2016/08/01 全球购物
Trip.com香港网站:Ctrip携程旗下,全球最大的网上旅游社之一
2016/08/01 全球购物
全球知名旅游社区法国站点:TripAdvisor法国
2016/08/03 全球购物
丝芙兰中国官方商城:SEPHORA中国
2018/01/10 全球购物
集世界奢侈品和设计师品牌的意大利精品买手店:Tessabit
2019/08/17 全球购物
FC-Moto英国:欧洲最大的摩托车服装和头盔商店之一
2019/08/25 全球购物
工作自我评价怎么写
2014/01/29 职场文书
一年级数学教学反思
2014/02/01 职场文书
2014年领导班子专项整治整改方案
2014/09/28 职场文书
鸡毛信观后感
2015/06/11 职场文书
《悲惨世界》:比天空更广阔的是人的心灵
2020/01/16 职场文书