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数据的更多相关文章

  1. python操作redis数据

    一.环境安装 1.redispy安装 (automatic) C:\Users\Administrator>pip install redis 2.检测是否安装成功 (automatic) C: ...

  2. python操作三大主流数据库(14)python操作redis之新闻项目实战②新闻数据的展示及修改、删除操作

    python操作三大主流数据库(14)python操作redis之新闻项目实战②新闻数据的展示及修改.删除操作 项目目录: ├── flask_redis_news.py ├── forms.py ├ ...

  3. 第三百节,python操作redis缓存-其他常用操作,用于操作redis里的数据name,不论什么数据类型

    python操作redis缓存-其他常用操作,用于操作redis里的数据name,不论什么数据类型 delete(*names)根据删除redis中的任意数据类型 #!/usr/bin/env pyt ...

  4. Python—操作redis

    Python操作redis 连接方式:点击 1.String 操作 redis中的String在在内存中按照一个name对应一个value来存储 set() #在Redis中设置值,默认不存在则创建, ...

  5. python——操作Redis

    在使用django的websocket的时候,发现web请求和其他当前的django进程的内存是不共享的,猜测django的机制可能是每来一个web请求,就开启一个进程去与web进行交互,一次来达到利 ...

  6. Python操作Redis、Memcache、RabbitMQ、SQLAlchemy

    Python操作 Redis.Memcache.RabbitMQ.SQLAlchemy redis介绍:redis是一个开源的,先进的KEY-VALUE存储,它通常被称为数据结构服务器,因为键可以包含 ...

  7. 数据库之redis篇(3)—— Python操作redis

    虽然前面两篇已经说了redis的一些配置安装什么的,篇幅有点长,可能看完了也不知道怎么操作,这里再浓缩一下: 什么是redis redis完全开源免费的,遵守BSD协议,是一个高性能的非关系型key- ...

  8. python操作redis命令

    Python操作redis from redis import StrictRedis, ConnectionPoolredis_url="redis://:xxxx@112.27.10.1 ...

  9. Python操作Redis及连接方式

    前沿:随着互联网的高速发展,数据变得越来越重要,Python成为了人工智能的热门语言,而Nosql数据库已成为日常开发用品. 今天要写的是Python操作Redis Redis的安装我就不介绍了,你可 ...

随机推荐

  1. 图形设计 X11

    显示适配器驱动程序安装范例 AMD驱动加载 Intel驱动加载

  2. Quartz -----定时任务框架

    一.什么是Quartz     由java开发用来执行定时任务,类似于java.util.Timer.   但是相较于Timer,quartz增加了很多功能:                  持久性 ...

  3. centos 升级python

    1.下载python3.6.1的包 wget https://www.python.org/ftp/python/3.6.1/Python-3.6.1.tgz 2.解压 tar -zxvf Pytho ...

  4. 使用 sar 查看网卡的流量

    1.常用命令 sar -n DEV #查看当天从零点到当前时间的网卡流量信息 sar -n DEV 1 10 #每秒显示一次,共显示10次 sar -n DEV -f /var/log/sa/saxx ...

  5. The user specified as a definer ('root'@'%') does not exist解决

    转自:https://www.cnblogs.com/hanxue53/p/5850263.html 解决方法: 2.进入mysql的安装路径之前,要确保你的mysql服务是开启的: 在DOS命令窗口 ...

  6. 这样才能正确解锁MaxCompute客户端

    大数据计算服务(MaxCompute,原名ODPS)是一种快速.完全托管的TB/PB级数据仓库解决方案.MaxCompute向用户提供了完善的数据导入方案以及多种经典的分布式计算模型,能够更快速的解决 ...

  7. Python之-爬虫

    1.得到页面的HTML代码 第一个参数是URL 第二三个参数可以不传送,数据和时间 2.request请求 HTTP是基于请求和应答的,客户端发出请求,服务端做出响应,所以urllib2创建一个req ...

  8. centos6编译安装php7

    https://www.cnblogs.com/wenwei-blog/p/6261637.html https://www.cnblogs.com/imzye/p/5109770.html cent ...

  9. 升级到Xcode 5.1和iOS 7遇到的各种问题及解决办法汇总:

    <iOS 企业证书部署无效的问题>:http://t.cn/8s7ILWZ <clipsToBounds 属性默认值变了>:http://weibo.com/165881473 ...

  10. 网页实时聊天之PHP如何实现websocket

    网页实时聊天之PHP如何实现websocket 一.总结 一句话总结: 应用 PHP 的 socket 函数库:PHP 的 socket 函数库跟 C 语言的 socket 函数非常类似 PHP 实现 ...