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的安装我就不介绍了,你可 ...
随机推荐
- nodejs包高效升级插件npm-check-updates
一.安装 npm install -g npm-check-updates 或 cnpm install -g npm-check-updates 二.使用 ncu crypto ^0.0.3 → ^ ...
- EventBus总结(原)
1.EventBus的作用 EventBus is a publish/subscribe event bus for Android and Java. EventBus可以被用来在各种自定义的监听 ...
- 力扣—set matrix zeroes (矩阵置零) python实现
题目描述: 中文: 给定一个 m x n 的矩阵,如果一个元素为 0,则将其所在行和列的所有元素都设为 0.请使用原地算法. 英文: Given a m x n matrix, if an eleme ...
- 转 关于HTML5中meta name="viewport" 的用法 不同分辨率手机比例缩放
移动端的布局不同于pc端,首先我们要知道在移动端中,css中的1px并不等于物理上的1px,因为手机屏幕的分辨率已经越来越高,高像素但是屏幕尺寸却没有发生太大变化,那就意味着一个物理像素点实际上塞入了 ...
- 阿里云ssh免密登陆突然无效
[root@node03 ~]# ssh-copy-id node02 root@node02's password: sh: .ssh/authorized_keys: Permission den ...
- 【leetcode】907. Sum of Subarray Minimums
题目如下: 解题思路:我的想法对于数组中任意一个元素,找出其左右两边最近的小于自己的元素.例如[1,3,2,4,5,1],元素2左边比自己小的元素是1,那么大于自己的区间就是[3],右边的区间就是[4 ...
- 【Http】队头阻塞(Head of line blocking)多路复用(Multiplexing)
图中第一种请求方式,就是单次发送request请求,收到response后再进行下一次请求,显示是很低效的. 于是http1.1提出了管线化(pipelining)技术,就是如图中第二中请求方 ...
- FTP上传脚本
脚本名称:uploadToFtp.sh 脚本用途:上传文件到FTP服务器 脚本参数:$1:FTP服务器的路径,$2:本地文件 #!/bin/bash FTP_USER="testfile&q ...
- sql server 基础语法2
别名,选择,查询,排序,去重,筛选 select * from UserInfo as ui --起别名 select UserName,UserPwd --指定选择的列 from UserInfo ...
- Android学习--apk打包过程
1. 使用aapt工具,给所有的res目录下的资源文件生成对应的id,id会被放进R.java文件中 2. JavaC编译器,将所有Java文件转换为Class文件,其中,内部类会分别生成.class ...