redis api之python操作整理

1.简介

Redis 是一个基于内存的高效的键值行非关系型数据库,存取效率极高。

python提供了两个类:分别为RedisStrictRedis来实现Redis的命令操作。StrictRedis用于实现大部分官方的命令,并使用官方的语法和命令,Redis是StrictRedis的子类,用于向后兼容旧版本的redis-py。

redis连接实例是线程安全的,可以直接将redis连接实例设置为一个全局变量,直接使用。如果需要另一个Redis实例(or Redis数据库)时,就需要重新创建redis连接实例来获取一个新的连接。同理,python的redis没有实现select命令。

官方推荐使用StrictRedis

如果要做数据导入、导出操作的话,还需要安装RedisDump

2.连接Redis-api

安装redis模块

pip install redis

python操作

import redis
 ​
 client = redis.StrictRedis(host='127.0.0.1', port=6379, db=1, password=None, decode_responses=True)     # 密码在redis中的配置文件,如果启用就要传递
 # decode_responses 默认False 那么redis返回的是二进制,是True则返回字符串
 ​
 默认参数如下:
 # def __init__(self, host='localhost', port=6379,
 #                 db=0, password=None, decode_responses=False
 #           ... )
 ​
 client.set('name','Jack', ex=10)    # ex为设置的过期时间,单位为秒,默认为None
 print(client.get('name'))

连接redis,加上decode_responses=True,写入的键值对中的value为str类型,不加这个参数写入的则为字节类型。

连接池

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

import redis    

pool = redis.ConnectionPool(host='localhost', port=6379, decode_responses=True)   
# host是redis主机,需要redis服务端和客户端都起着 redis默认端口是6379

r = redis.Redis(connection_pool=pool)
r.set('gender', 'male')     # key是"gender" value是"male" 将键值对存入redis缓存
print(r.get('gender'))      # gender 取出键male对应的值

连接问题及解决

出现拒绝连接,如果不是本机连接,就需要修改远程redis的配置文件。

cd /etc/redis/  # 有的配置文件就在/etc/目录下
 ​
sudo vim redis.conf
# 修改 bind 为 0.0.0.0 ::1
bind 0.0.0.0 ::1
 ​
# 如果想使用密码,启用下面这行,foobared就是默认的密码,也可以自行修改
# requirepass foobared      # 去掉注释, 那么连接时也要密码,不推荐启用
 ​
service redis-server restart    # 重启服务
 ​
# 设置端口转发为 6379

3.全局键(key)操作

# 全局key操作:
results = cli.keys(pattern='*')  # 查询全部key的值。默认查找所有
cli.exists('sex')  # 查询该键是否存在
cli.rename('yelan', 'ze')  # 改名
cli.expire('name', 200)  # 设置过期时间
cli.ttl('name')  # 查看过期时间
cli.persist('name')  # 删除过期时间
cli.delete('name')   # 删除键值对

4.键值操作

str类型

 cli.set('yelan', 'hello')  # 增
 cli.mset(name='liu', sex=18)  # 增加多条
 cli.append('yelan', '	world')  # 追加数据
 result = cli.get('yelan')  # 查
 print(result.title())
 result = cli.mget('name', 'sex')  # 查询多条
 print(result)
 cli.delete('yelan', 'name')  # 删(不定长)

list类型

 cli.rpush('name', 'wang', 'li', 'liu')  # 尾部插入
 cli.lpush('sex', 'n', 'w', 'n')  # 头部插入(倒序)
 results = cli.lrange('name', 0, 5)  # 查询(闭区间)
 print(results)
 result = cli.lindex('name', 2)  # 查询指定索引的值
 cli.lset('name', 1, 'muzi')  # 修改指定索引的值
 cli.rpop('name')  # 尾部删除key的值
 cli.lpop('name')  # 头部删除
 cli.lrem('name', 1, 'liu')  # 指定次数指定删除值

hash类型

 cli.hset('info', 'tel', 177)  # 添加数据
 cli.hset('info', 'tel', 150)  # 修改数据(同则修改,无则添加)
 cli.hset('info', 'sex', 'nan')
 result = cli.hget('info', 'tel')  # 查看指定域对应的值
 result = cli.hgetall('info')  # 查询所有的field和value(返回一个字典格式)
 result = cli.hvals('info')  # 查看所有的值values
 result = cli.hkeys('info')  # 查看所有的域field
 print(result)
 cli.delete('info')  # 删除

Set类型

 client.sadd()
 client.smembers()
 client.spop()
 client.srem()

zset类型

 client.zadd()
 client.zrange()
 client.zscore()
 client.zrangebyscore()
 client.zrem()
 client.zremrangebyrank()
 client.zremrangebyscore()

5.自定义封装

全局key操作封装

import redis
 ​
class GlobalKey:
     def __init__(self, db=0, decode_response=False):
         self.conn = redis.StrictRedis(db=db, decode_responses=decode_response)
 ​
     def check_all(self, key="*"):
         result = self.conn.keys(key)    # 查询全部key
         print(result)
 ​
     def set_expire(self, key, seconds):     # 设置过期时间
         self.conn.expire(key, seconds)
 ​
     def check_type(self, key):              # 查看key类型
         res = self.conn.type(key)
         print(res)
 ​
     def check_exists(self, key):            # 查看key是否存在
         res = self.conn.exists(key)
         print(res)
 ​
     def check_ttl(self, key):               # 查看剩余的过期时间
         res = self.conn.ttl(key)
         print(res)
 ​
     def change_name(self, key, new_key):    # 重命名
         self.conn.rename(key, new_key)
 ​
     def globl_del(self, *key):              # 全局删除操作
         self.conn.delete(*key)
 ​
 gk = GlobalKey(1, decode_response=True)
 gk.check_all()

字符串操作封装

class RedisString:
     def __init__(self, db=0, decode_response=False):
         self.conn = redis.StrictRedis(db=db, decode_responses=decode_response)
 ​
     def str_set(self, key, value):
         self.conn.set(key, value)
 ​
     def str_mset(self, dict_):
         self.conn.mset(dict_)
 ​
     def str_append(self, key, value):
         self.conn.append(key, value)
 ​
     def str_get(self, key):
         res = self.conn.get(key)
         print(res)
 ​
     def str_del(self, key):
         self.conn.delete(key)
 ​
 ​
 # my_str = RedisString(1, decode_response=True)
 # my_str.str_mset({'name': 'liu', 'age': 18})
 # my_str.str_del("age")

列表类型操作封装

class RedisList:
     def __init__(self, n=0, decode_responses=False):  # 初始化时连接redis n号数据库
         self.client = redis.StrictRedis(db=n, decode_responses=decode_responses)
 ​
     def push(self, key, *values, l=True):  # 增加数据
         if l:
             self.client.lpush(key, *values)  # 头部插入
         else:
             self.client.rpush(key, *values)  # 尾部插入
 ​
     def lrange(self, key, start, stop):  # 查询数据
         result = self.client.lrange(key, start, stop)
         print(result)  # 查询的结果需要打印
 ​
     def lset(self, key, index, value):  # 修改数据
         self.client.lset(key, index, value)
 ​
     def pop(self, key, R=True):  # 删除数据
         if R:
             self.client.rpop(key)
         else:
             self.client.lpop(key)
 ​
     def remove(self, key, count, value):  # 指定删除数据
         self.client.lrem(key, count, value)
 ​
 if __name__ == "__main__":
 ​
 my_list = RedisList(n=2, decode_responses=True)  # 实例化时传入2号数据库
 my_list.push('sex', 'man', 'nv', l=False)
 my_list.lrange('sex', 0, 10)
 my_list.lset('sex', 2, 'wo')
 my_list.pop('sex', R=False)
 my_list.remove('sex', 0, '男')

散列类型操作封装

 class Redis_Hash:
     def __init__(self, db, is_str=False):
         self.conn = redis.StrictRedis(db=db, decode_responses=is_str)
 ​
     def hash_set(self, hash_key, field, value):
         self.conn.hset(hash_key, field, value)
 ​
     def hash_mset(self,key, dict_):
         self.conn.hmset(key, dict_)
 ​
     def hash_get(self, key, field):
         res = self.conn.hget(key, field)
         print(res)
 ​
     def hash_getall(self, key):
         res = self.conn.hgetall(key)
         print(res)
 ​
     def hash_hvals(self, key):
         res = self.conn.hvals(key)
         print(res)
 ​
     def hash_hkey(self, key):
         res = self.conn.hkeys(key)
         print(res)
 ​
     def hash_del(self, *key):
         self.conn.delete(*key)
 ​
 my_hash = Redis_Hash(1, True)
 my_hash.hash_mset('info', {"name": 18})
 my_hash.hash_del('info')

https://www.cnblogs.com/yelan5222/p/12080296.html

原文地址:https://www.cnblogs.com/davis12/p/14439690.html