redis的基本操作:

redis_conf ={
'host':'192.168.64.128',
'password':'Aa123456',
'db':'0',
'port':6379,
'decode_responses':True # 自动将bytes转换为 string 类型
}
r = redis.Redis(**redis_conf) # string 入参只能为字符串
# key-value形式 增加key 修改
r.set('矿泉水','{"price":111,"count":11}') # 根据key查询
data1 = r.get('矿泉水')
print(type(data1),data1) # 根据key删除
r.delete('矿泉水') # 删除key-value # 设置失效时间
expire_time = 5
r.set('tl_session','asdfdfd',expire_time) # hash 类型
# {"kqs":{xxx},"笔":{xxx}}
# 新增 修改
r.hset('students','fd','{"money":19999}')
r.hset('students','ds','{"money":19111999}')
r.hset('students','lhy','{"money":19111999}')
r.hset('students','ljj','{"money":19111999}') # 查询
print(r.hget('students','ds'))
d = r.hgetall('students')
print(d)
# 如果没有decode_responses=True 则 需要 每次decode
print({k.decode():v.decode() for k,v in d.items()}) # 删除
r.hdel('students','ds') # 删除某个小key
r.delete('students') # 删除大key # 过期时间设置
r.expire('students',10)#指定某个key的过期时间 只能对大key设置 小key不能设置 # 从redis获取数据 需要知道key是什么 和 key的类型是什么 # 获取当前数据库中 的 所有keys
print(r.keys()) # 获取当前数据库中 s开头的keys
print(r.keys('s*')) # 查看key的类型
print(r.type('stu'))
print(r.type('students')) #清空当前数据库里面所有的key
print(r.flushdb()) #清空所有数据库里面所有的key
print(r.flushall()) # 管道,批量操作
p = r.pipeline()#建立管道
p.set('xiaoming','shabi')
p.get('xiaoming')
p.execute() # 批量执行
p.exists('students123') # 判断key是否存在
s = p.execute()
print(s)
print(r.exists('students')) # 直接返回结果 p.hgetall('students')
p.hset('students','fd','{"money":19999}')
p.hset('students','ds','{"money":19111999}')
p.hset('students','lhy','{"money":19111999}')
p.hset('students','ljj','{"money":19111999}')
s = p.execute() #执行,返回一个list,这个list里面是每个命令执行的结果
print(s) # 管道批量执行 和 单个执行的速度快慢比较
start_time = time.time()
for i in range(100):
r.set(f"key{i}",f"{i}")
print('不用管道的时间',time.time() - start_time) start_time = time.time()
p = r.pipeline()
for i in range(100):
p.set(f"pipline_key{i}", f"{i}")
p.execute()
print('用管道的时间',time.time() - start_time) # string类型 展示带文件夹的
r.set('product:kqs','{"count":1,"price":5555}')
r.set('product:apple','{"count":1,"price":5555}')
r.set('product:banana','{"count":1,"price":5555}') #a服务器 -》迁移
#b服务器,redis r = redis.Redis(host='192.168.64.128',
password='Aa123456',
port=6379,
db=0,
decode_responses=True
)
r2 = redis.Redis(host='192.168.64.128',
password='Aa123456',
port=6379,
db=15,
decode_responses=True
) p = r2.pipeline() for k in r.keys():
key_type = r.type(k)
if key_type == 'string':
value = r.get(k)
p.set(k,value)
elif key_type=='hash':
hash_data = r.hgetall(k) #{'xx':xxx}
for field,data in hash_data.items():
p.hset(k,field,data) p.execute() #bytes #字节类型 b'{"price":111,"count":11}'
data = r.get('矿泉水').decode() #bytes类型 转换为 string类型
s = '你好啊'
print(s.encode()) #string类型 转换为 bytes类型

封装的基本工具:

import hashlib

import pymysql,traceback,xlwt
import redis redis_conf ={
'host':'192.168.64.128',
'password':'Aa123456',
'db':'0',
'port':6379,
'decode_responses':True # 自动将bytes转换为 string 类型
}
MYSQL_INFO = {
'host':'192.168.64.128',
'user':'root',
'password':'Aa123456@',
'db':'besttest_db',
'port':3306,
'charset':'utf8',
'autocommit':True
}
def execute_sql(sql,only=False):
conn = pymysql.connect(**MYSQL_INFO)
cur = conn.cursor(pymysql.cursors.DictCursor)
try:
cur.execute(sql)
except:
print("sql不正确:",traceback.format_exc())
else:
if only:
return cur.fetchone()
return cur.fetchall()
finally:
cur.close()
conn.close()
def write_excel(name,data):
book = xlwt.Workbook()
sheet = book.add_sheet('sheet1')
for index, key in enumerate(data[0]): # 写表头
sheet.write(0, index, key)
for row, item in enumerate(data, 1): # 写数据
for col, value in enumerate(item.values()):
sheet.write(row, col, value) book.save(f"{name}.xls") def my_md5(s):
m = hashlib.md5(str(s).encode())
return m.hexdigest() class Ope_Redis:
def __init__(self,redis_conf):
self.r = redis.Redis(**redis_conf)
self.p = self.r.pipeline() # 建立管道
def set_key(self,key,value,ttl):
self.p.set(key,value,ttl)
def get_key(self,key):
return self.r.get(key)
def set_hash_key(self,field,key,value):
self.p.hset(field,key,value)
def get_hash_key(self,field=None,key=None):
if key is not None and field is not None:
return self.r.hget(field,key)
elif key is None and field is not None:
return self.r.hgetall(field)
def p_execute(self):
self.p.execute() def redis_str(key,value=False,expire_time=None):
r = redis.Redis(**redis_conf)
if value:
r.set(key,value,expire_time)
else:
return r.get(key) def redis_hash():
pass def check_session(session_id):
result = redis_str(session_id)
return result if result else False

python基础篇 26-redis操作的更多相关文章

  1. python基础篇 08 文件操作

    本节主要内容:1. 初识⽂件操作2. 只读(r, rb)3. 只写(w, wb)4. 追加(a, ab)5. r+读写6. w+写读7. a+写读(追加写读)8. 其他操作⽅法9. ⽂件的修改以及另⼀ ...

  2. python基础篇(文件操作)

    Python基础篇(文件操作) 一.初始文件操作 使用python来读写文件是非常简单的操作. 我们使用open()函数来打开一个文件, 获取到文件句柄. 然后通过文件句柄就可以进行各种各样的操作了. ...

  3. python基础篇(六)

    PYTHON基础篇(六) 正则模块re A:正则表达式和re模块案例 B:re模块的内置方法 时间模块time A:时间模块的三种表示方式 B:时间模块的相互转换 随机数模块random A:随机数模 ...

  4. python基础篇-day1

    python基础篇 python是由C语言写的: pass 占位符: del,python中全局的功能,删除内存中的数据: 变量赋值的方法: user,pass = 'freddy','freddy1 ...

  5. python基础篇之进阶

    python基础篇之进阶 参考博客:http://www.cnblogs.com/wupeiqi/articles/5115190.html python种类 1. cpython  使用c解释器生产 ...

  6. python基础篇(五)

    PYTHON基础篇(五) 算法初识 什么是算法 二分查找算法 ♣一:算法初识 A:什么是算法 根据人们长时间接触以来,发现计算机在计算某些一些简单的数据的时候会表现的比较笨拙,而这些数据的计算会消耗大 ...

  7. python基础篇(一)

    PYTHON基础篇(一) 变量 赋值 输入,输出和导入 A:输入 B:输出 C:导入 运算符 A:算数运算符 B:比较运算符 C:赋值运算符 D:位运算符 E:逻辑运算符 F:成员运算符 G:身份运算 ...

  8. python基础篇(二)

    PYTHON基础篇(二) if:else,缩进 A:if的基础格式和缩进 B:循环判断 C:range()函数和len()函数 D:break,contiue和pass语句 for,while循环 函 ...

  9. python基础篇(三)

    PYTHON基础篇(三) 装饰器 A:初识装饰器 B:装饰器的原则 C:装饰器语法糖 D:装饰带参数函数的装饰器 E:装饰器的固定模式 装饰器的进阶 A:装饰器的wraps方法 B:带参数的装饰器 C ...

  10. python基础篇(四)

    PYTHON基础篇(四) 内置函数 A:基础数据相关(38) B:作用域相关(2) C:迭代器,生成器相关(3) D:反射相关(4) E:面向对象相关(9) F:其他(12) 匿名函数 A:匿名函数基 ...

随机推荐

  1. vue3 门户网站搭建6-wangeditor

    门户网站的新闻.公告等文章,内容可配置,故引入 wagneditor 1.安装: npm i wangeditor 2.方便调用,抽成组件: <template> <div ref= ...

  2. (0502)《UVM》sequence

  3. Educational Codeforces Round 143 (Rated for Div

    Educational Codeforces Round 143 (Rated for Div. 2) Problem - B Ideal Point 给定n个线段区间\([l,r]\),我们定义\( ...

  4. charls抓包的乱码问题解决

    1. 在charls的安装目录下,去修改配置文件的值 ----Charles.ini,内容如下 2. SSL proxy setting 设置如下图 3. 顺便说一下,charls抓取 https的包 ...

  5. C#判断窗体是否打开,并获取聚焦、未打开则新建一个子窗体

    在桌面程序开发会遇到的情况,托盘功能或者是小功能弹窗问题: 现有一个主窗体有子窗体 子窗体每个都可以新建其他窗体问题:新建子窗体时怎么判断子窗体是否打开?若子窗体打开则置顶获取焦点.若未打开则新建一个 ...

  6. csp-s2020 T2 动物园

    题目简述: 共有n个动物,m条要求,每条要求描述了第x位上是1的话,必须购买y饲料,动物园里已有的动物必须的饲料已经购买了,问题是:在不要求增加购买饲料的基础上,还能放进去多少种动物?共有k个二进制, ...

  7. OSPF配置知识总结3(多区域配置)

    OSPF配置知识总结3(多区域配置) 1.相关解释: 要解决网络规模大了以后的问题:网络的扩展性,降低路由器负载,实现路由的更快收敛 OSPF多区域的区域类型分为Area 0(骨干区域), 以及非Ar ...

  8. Ios安装charles

    1.浏览器打开chls.pro/ssh,不会弹出下载证书,所以使用以下方式: 2. 然后打开设置,可以看到描述文件,安装 检查:在"设置"-"描述文件"-查看描 ...

  9. 【阿里云ACP】-03(数据库RDS)

    OSS快速使用入门:创建Bucket 1.用户创建一个Bucket时,可以根据费用单价.请求来源分布.响应延迟等方面的考虑,为该bucket选择所在的数据中心 阿里云所有数据中心都提供OSS公众服务 ...

  10. SignalR 的应用

    一.应用场景: 在项目中有一个地方需要定时查询数据库是否有数据,如果有则显示在界面上. 二.可以使用ajax定时查询来做: var inter = window.setInterval(refresh ...