python 操作redis数据
python 操作redis 各种类型的数据
# encoding:utf-8
import redis
import time def main():
"""
redis-cli -h 127.0.0.1 -a test321
"""
redis_host = "127.0.0.1"
redis_password = "test321"
redis_cli = redis.StrictRedis(host=redis_host, password=redis_password)
try:
key = "TEST_KEY_1484"
# string
print redis_cli.delete(key)
print redis_cli.set(key, "hello")
print redis_cli.get(key)
print redis_cli.append(key, "world")
print redis_cli.get(key)
print redis_cli.strlen(key)
# timeout
print redis_cli.delete(key)
print redis_cli.setex(key, 10, "hello")
print redis_cli.get(key)
print redis_cli.ttl(key)
# time.sleep(10)
print redis_cli.get(key)
# not set
print redis_cli.delete(key)
print redis_cli.setnx(key, "hello") # 设置key为hello
print redis_cli.setnx(key, "world") # 设置key为world,key已经有值,设置失败
print redis_cli.get(key) # 只能得到第一次设置的值
print redis_cli.setrange(key, 20, "") # 从20位置开始替换,若索引值超过原值长度,则补0
print redis_cli.getrange(key, 1, -1) # 获取1到-1(最后)的子串
print redis_cli.mset({"key1":1, "key2":2, "key3":3})
print redis_cli.mget("key1", "key2", "key3")
print redis_cli.msetnx({"key3":7, "key4":8, "key5":9}) # 已经有值的key会设置失败,从而导致整次设置失败
print redis_cli.mget("key1", "key2", "key3", "key4", "key5") # integer
print redis_cli.delete(key)
print redis_cli.set(key, 1)
print redis_cli.incr(key) # 累加1
print redis_cli.incr(key, 2) # 累加2
print redis_cli.incrby(key, 5) # 累加5
print redis_cli.decr(key) # 累减1
print redis_cli.decr(key, 3) # 累减3
print redis_cli.getset(key, 0) #获取旧值,并获取新值,一次原子操作 # list
print redis_cli.delete(key) # 删除key
print redis_cli.lpush(key, 1,2,3,4,5) # 从左添加元素,若key不存在添加key
print redis_cli.lpushx(key, 6) # 从左添加元素,返回添加后元素个数,若key不存在不做任何操作,返回0, 只能添加一个元素
print redis_cli.lpop(key) # 弹出left头部元素
print redis_cli.llen(key) # 获取链表长度
print redis_cli.lrange(key, 0, -1) # 取从位置0开始到位置-1(最后)结束的元素。
print redis_cli.lrem(key, 1, 1) # 从头部(left)向尾部(right)变量链表,删除2个值等于a的元素,返回值为实际删除的数量。
print redis_cli.lrem(key, 1, 1) # 从头部(left)向尾部(right)变量链表,删除2个值等于a的元素,返回值为实际删除的数量。
print redis_cli.lset(key, 1, 2) # 将左起索引值为1的元素值设置为新值2。
print redis_cli.lindex(key, 1) # 查看左起索引值为1的元素值
print redis_cli.ltrim(key, 0, 2) # 保留左起索引值0到2之间的3个元素,注意第0个和第2个元素均被保留。
ele1 = redis_cli.lindex(key, 1) # 获取左起索引值为1的元素值
print redis_cli.linsert(key, "after", ele1, 88) # 在1号元素后插入元素88
print redis_cli.lrange(key, 0, -1)
print redis_cli.linsert(key, "before", ele1, 99) # 在1号元素前插入元素99
print redis_cli.lrange(key, 0, -1)
# r
print redis_cli.delete(key)
print redis_cli.rpush(key, 1,2,3,4,5)
print redis_cli.lrange(key, 0, -1)
print redis_cli.rpushx(key, 6)
print redis_cli.lrange(key, 0, -1)
print redis_cli.rpop(key) # 从最右po出元素
print redis_cli.lrange(key, 0, -1)
newkey = key+"new"
print redis_cli.lpush(key, 1,1)
print redis_cli.rpoplpush(key, newkey) # 从key尾部po出元素到newkey头部
print redis_cli.lrange(key, 0, -1)
print redis_cli.lrange(newkey, 0, -1) # set
print redis_cli.delete(key)
print redis_cli.sadd(key, 1,2,3,4,5) # 添加、设置成员
print redis_cli.smembers(key) # 获取成员
print redis_cli.scard(key) # 获取成员数量
print redis_cli.sismember(key, 4) # 判断是否包含该成员
print redis_cli.srandmember(key) # 随机获取一个成员,成员依然在Set中存在
print redis_cli.smembers(key) # 查看成员
print redis_cli.spop(key) # 从尾部弹出一个元素,由于是Set所以得到并不是之前插入的第一个或最后一个成员。
print redis_cli.smembers(key) # 查看成员
print redis_cli.srem(key, 1) # 删除一个成员
print redis_cli.smembers(key) # 查看成员
key1 = key+"B"
print redis_cli.sadd(key1, 9,8,7)
print redis_cli.smove(key, key1, 2) # 将2从key移到key1
print redis_cli.smove(key, key1, 2) # 将2从key移到key1, 由于此时key中没有2,移动失败
print redis_cli.smembers(key) # 查看成员
print redis_cli.smembers(key1) # 查看成员
# 与、或、非
key2 = key+"C"
print redis_cli.delete(key)
print redis_cli.sadd(key, 1,2,3) # 添加、设置成员
print redis_cli.sadd(key1, 1,4,5) # 添加、设置成员
print redis_cli.sadd(key2, 3,6,9) # 添加、设置成员
print redis_cli.sinter(key, key1, key2) # 取交集
interkey = key+"inter"
print redis_cli.sinterstore(interkey, key, key1, key2) # 取交集并存储
print redis_cli.delete(interkey)
print redis_cli.sunion(key, key1, key2) # 取并集
unionkey = key+"unionkey"
print redis_cli.sinterstore(unionkey, key, key1, key2) # 取并集并存储
print redis_cli.delete(unionkey)
print redis_cli.sdiff(key, key1, key2) # 取非,key和key1相比,再用这个结果继续和key2进行差异比较
notkey = key+"not"
print redis_cli.sdiffstore(unionkey, key, key1, key2) # 取非,并存储
print redis_cli.delete(notkey)
# Sorted-Sets和Sets类型极为相似,各种操作命令也相似
print redis_cli.delete(key)
print redis_cli.zadd(key, 1, "one", 2, "two", three=3, four=4) # 添加、设置成员
print redis_cli.zcard(key) # 获取成员数量
print redis_cli.zcount(key, 1, 2) # 获取分数满足表达式1 <= score <= 2的成员的数量
print redis_cli.zscan(key, match="*o*") # 查看匹配的成员
print redis_cli.zrange(key, 0, -1) # 查看所有成员。
print redis_cli.zrange(key, 0, -1, withscores=True) # WITHSCORES选项表示返回的结果中包含每个成员及其分数,否则只返回成员。
print redis_cli.zrank(key, "one") # 查看成员one的索引位置
# print redis_cli.zrem(key, "one", "two") # 删除成员one和two,返回实际删除成员的数量。
print redis_cli.zscore(key, "one") # 获取成员one的分数。返回值是字符串形式。
print redis_cli.zincrby(key, "one", 2) # 将成员one的分数增加2,并返回该成员更新后的分数。
print redis_cli.zincrby(key, "one", -1) # 将成员one的分数增加-1,并返回该成员更新后的分数。
print redis_cli.zrange(key, 0, -1, withscores=True)
print redis_cli.zrangebyscore(key, 1, 3, start=1, num=2, withscores=True) # 获取分数满足表达式1 <= score <= 3的成员。
print redis_cli.zrangebyscore(key, 1, 3, 1, 2, True) # 获取分数满足表达式1<= score<= 3的成员。从1开始取2个,同时返回分数
# dict
print redis_cli.delete(key)
except Exception as e:
print e.message
finally:
print redis_cli.delete(key)
return None if __name__ == "__main__":
main()
github:https://github.com/luohuaizhi/test/blob/master/testRedisData.py
python 操作redis数据的更多相关文章
- python操作redis数据
一.环境安装 1.redispy安装 (automatic) C:\Users\Administrator>pip install redis 2.检测是否安装成功 (automatic) C: ...
- python操作三大主流数据库(14)python操作redis之新闻项目实战②新闻数据的展示及修改、删除操作
python操作三大主流数据库(14)python操作redis之新闻项目实战②新闻数据的展示及修改.删除操作 项目目录: ├── flask_redis_news.py ├── forms.py ├ ...
- 第三百节,python操作redis缓存-其他常用操作,用于操作redis里的数据name,不论什么数据类型
python操作redis缓存-其他常用操作,用于操作redis里的数据name,不论什么数据类型 delete(*names)根据删除redis中的任意数据类型 #!/usr/bin/env pyt ...
- Python—操作redis
Python操作redis 连接方式:点击 1.String 操作 redis中的String在在内存中按照一个name对应一个value来存储 set() #在Redis中设置值,默认不存在则创建, ...
- python——操作Redis
在使用django的websocket的时候,发现web请求和其他当前的django进程的内存是不共享的,猜测django的机制可能是每来一个web请求,就开启一个进程去与web进行交互,一次来达到利 ...
- Python操作Redis、Memcache、RabbitMQ、SQLAlchemy
Python操作 Redis.Memcache.RabbitMQ.SQLAlchemy redis介绍:redis是一个开源的,先进的KEY-VALUE存储,它通常被称为数据结构服务器,因为键可以包含 ...
- 数据库之redis篇(3)—— Python操作redis
虽然前面两篇已经说了redis的一些配置安装什么的,篇幅有点长,可能看完了也不知道怎么操作,这里再浓缩一下: 什么是redis redis完全开源免费的,遵守BSD协议,是一个高性能的非关系型key- ...
- python操作redis命令
Python操作redis from redis import StrictRedis, ConnectionPoolredis_url="redis://:xxxx@112.27.10.1 ...
- Python操作Redis及连接方式
前沿:随着互联网的高速发展,数据变得越来越重要,Python成为了人工智能的热门语言,而Nosql数据库已成为日常开发用品. 今天要写的是Python操作Redis Redis的安装我就不介绍了,你可 ...
随机推荐
- SQL笔试题:下面是学生表(student)的结构说明
SQL笔试题:下面是学生表(student)的结构说明 SQL笔试题:下面是学生表(student)的结构说明 字段名称 字段解释 字段类型 字段长度 约束 s_id 学号 字符 10 PK s_na ...
- 练手项目之image caption问题记录
小白一个,刚刚费了老大的劲完成一个练手项目--image caption,虽然跑通了,但是评估结果却惨不忍睹.于是贴上大神的作品,留待日后慢慢消化.顺便记录下自己踩坑的一些问题. 先膜拜下大神的作品. ...
- css3-手把手 transform 小时钟
学习css3ing,正在学习transfomr,突发奇想用此做个小时钟,开始吧: 准备前期工作,把时钟的表盘,时分秒针,实时时间标签 的大概样子做好,效果如图: html代码如下: <div c ...
- 【纪中集训】2019.08.02【NOIP提高组】模拟 A 组TJ
\(\newcommand{\RNum}[1]{\uppercase\expandafter{\romannumeral #1\relax}}\) T1 一道可以暴力撵标算的题-- Descripti ...
- UNP学习第八章udp
一.基本UDP套接口编程 #include <sys/socket.h> ssize_t recvfrom(int sockfd, void *buff, size_t nbytes, i ...
- GPIO软件模拟IIC时序
一.MPU6050中的IIC时序 1.1 START和STOP SDA和SCL在高电平时,SDA拉低表示START.SCL拉低,表示可以传输数据. SDA和SCL在低电平时,SDA拉高表示STOP. ...
- 【从0到1,搭建Spring Boot+RESTful API+Shiro+Mybatis+SQLServer权限系统】02、创建新的SpringBoot项目
1.创建项目 得到项目架构 2.测试项目Web功能 默认端口为8080,运行后,输入localhost:8080/index即可访问到网页 到这里,项目构建成功!
- (转)使用OpenGL显示图像(三)绘制Shapes
绘制形状 编写:jdneo - 原文:http://developer.android.com/training/graphics/opengl/draw.html 在定义了使用OpenGL绘制的形状 ...
- os模块方法
OS 对象方法: 提供了处理文件及目录的一系列方法 os.rename(current_file_name, new_file_name) 重命名 os.remove(file_name) 删除文件 ...
- 1. 什么是Prometheus
什么是Prometheus Prometheus是一个最初在SoundCloud上构建的开源系统监视和警报工具包 .自2012年成立以来,许多公司和组织都采用了Prometheus,该项目拥有一个非常 ...