python学习笔记(十二)python操作redis
1、python要操作redis 首先需要安装redis模块,然后导入才能使用
安装:pip install redis
导入:import redis
2、连接redis
r = redis.Redis(host='192.168.21.129',password='123456',db=1,port=6379)
password在配置文件redis.conf中查看,port一般是6379,db可根据需要操作的数据库进行选择
3、redis的增删改查
redis中key所存储的值类型有多种,主要说明string类型和hash类型。用命令 redis 127.0.0.1:6379> TYPE KEY_NAME可查看值的存储类型。
以下是针对string类型的操作
r.set('user3','e10adc3949ba59abbe56e057f20f883e')#数据库里面新增一个值,修改也是set
r.setex('user1','e10adc3949ba59abbe56e057f20f883e',)#数据库里新增一个值,并且设置key的失效时间,最后这个参数是秒
r.set('session:user1',{"seessionid":"a5dfcb047721e02a6f8bff779c856165","login_time":""})#新增值,值都在一个session文件夹里面存储
print(r.get('user1'))#获取对应key的值,返回的类型是byte类型,需要解码
print(r.get('user1').decode())#获取到的value值解码
print(r.get('session:user1').decode())
print(r.keys())#获取所有的key,存在一个list里面,元素是byte类型,如:[b'user3', b'user1', b'session:user1']
#获取所有的key,并且解码输出
list = [k.decode() for k in r.keys()]
print(list) #输出如:['user3', 'user1', 'session:user1']
r.delete('user3')#删除指定的key
#删除所有的key需要循环
for k in r.keys():
r.delete(k)
以下是哈希类型 hash操作,嵌套字典
r.hset('info','张三','北京,本科,测试工程师')#hash类型存储方式会有两个key,大key(info)和小key(张三),但无法设置小key的失效时间
r.hset('info','李四','湖北,博士,Boss')
r.hset('info','王五','江西,博士,CEO')
r.hset('login_mll','test1','{"seessionid":a5dfcb047721e02a6f8bff779c815165,"login_time":201805051820}')
print(r.hget('info','张三').decode()) #指定大key和小key获取对应的数据
print(r.hgetall('info')) #获取里面所有的k和-v,所有的K,V存储在字典里,但是是byte类型 # 获取里面所有的k和-v,所有的K,V存储在字典里,并且解码输出
info = r.hgetall('info')
new_info = {}
for k,v in info.items():
new_info[k.decode()] = v.decode()
print(new_info) r.hdel('info','张三') #删除指定key
r.delete('info') #删除整个key
r.expire('info',) #第一个key设置失效时间,无法设置小key的失效时间
print(r.ttl('info'))#获取key的失效时间
print(r.type('info')) #查看key是什么类型的
小练习:将数据库中某个表的数据导入到redis中
分析:1、连数据库,查到数据库里面所有的数据,游标类型要用pymysql.curosrs.DictCour
2、查到所有数据 [ {"id":1,"passwd":"49487dd4f94008a6110275e48ad09448","username":"test","is_admin":1}]
3、循环这个list,取到usernamer,把username当做key
4、再把这个小字典转成json,存进去就ok。
import pymysql,json,redis
r = redis.Redis(host='192.168.21.129',password='HK139bc&*',db=,port=)
conn = pymysql.connect(host='192.168.21.129',user='jxz',passwd='',db='jxz',charset='utf8')
cur = conn.cursor(cursor=pymysql.cursors.DictCursor)
cur.execute('select * from my_user;')
all_data = cur.fetchall() #数据库某表里面所有数据,输出为list形式,list中每个元素为表中的每行数据,每行数据为字典形式
#如:[{'username': 'niuniu', 'is_admin': , 'id': , 'passwd': 'niuniu'}, {'username': 'xiaohei1234', 'is_admin': , 'id': , 'passwd': 'aA123456'}, {'username': 'gyx', 'is_admin': , 'id': , 'passwd': ''}
for data in all_data: #data为表中每行数据,是字典
k = data.get('username') #将username的值获取,作为小key
r.hset('stu_info_mkk',k,json.dumps(data)) #将data字典转为json字符串,新增到redis中
cur.close()
conn.close()
python学习笔记(十二)python操作redis的更多相关文章
- python学习笔记(十 二)、操作数据库
每一种语言都少不了多数据库进行各种操作. python支持多种数据库.有关python支持的数据库清单,请参阅:https://wiki.python.org/moin/DatabaseInterfa ...
- python3.4学习笔记(十二) python正则表达式的使用,使用pyspider匹配输出带.html结尾的URL
python3.4学习笔记(十二) python正则表达式的使用,使用pyspider匹配输出带.html结尾的URL实战例子:使用pyspider匹配输出带.html结尾的URL:@config(a ...
- Python学习笔记(十二)—Python3中pip包管理工具的安装【转】
本文转载自:https://blog.csdn.net/sinat_14849739/article/details/79101529 版权声明:本文为博主原创文章,未经博主允许不得转载. https ...
- Python学习笔记之二——Python的运行机制,一般人肯定不会
前言本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理.作者:XX Python解释器简介 解释器是一种让其他程序运行起来的程 ...
- python 学习笔记(十二) 文件和序列化
python 文件读写和序列化学习.## python文件读写`1 打开并且读取文件` f = open('openfile.txt','r') print(f.read()) f.close() ` ...
- python学习笔记(十)、文件操作
在前面我们了解到了没得模块,其中有一个模块为fileinput,为文件操作模块,不知道小伙伴们是否还记得? 1 打开文件 要打开文件,可以使用fileinput中的fileinput.input函数进 ...
- python 学习笔记十二 html基础(进阶篇)
HTML 超级文本标记语言是标准通用标记语言下的一个应用,也是一种规范,一种标准,它通过标记符号来标记要显示的网页中的各个部分.网页文件本身 是一种文本文件,通过在文本文件中添加标记符, 可以告诉浏览 ...
- python学习笔记十二:类的定义
demo #!/usr/bin/python class Person: name = 'jim' age = 25 def say(self): print 'My name is ' + self ...
- python学习笔记(十二)-网络编程
本文结束使用 Requests 发送网络请求.requests是一个很实用的Python HTTP客户端库,编写爬虫和测试服务器响应数据时经常会用到.可以说,Requests 完全满足如今网络的需求. ...
- Python学习笔记十二
HTML全称:Hyper Text Markup Language超文本标记语言 不是编程语言 HTML使用标记标签来描述网页 2. HTML标签 开始标签,结束标签. 例如:<html&g ...
随机推荐
- Latex之希腊字母表 花体字母 实数集
花体字母 \mathcal{x} 实数集字母 \mathbb{R} 转自:http://blog.csdn.net/lanchunhui/article/details/49819445 拉丁字母是2 ...
- UCASE() 函数
UCASE() 函数 UCASE 函数把字段的值转换为大写. SQL UCASE() 语法 SELECT UCASE(column_name) FROM table_name
- 【BZOJ】1616: [Usaco2008 Mar]Cow Travelling游荡的奶牛(dp/-bfs)
http://www.lydsy.com/JudgeOnline/problem.php?id=1616 我觉得bfs是可过的,但是交bfs上去是wa? 然后没办法看dp,原来这bfs能和dp联系在一 ...
- jenkins发布docker到mesos
1.前提是装好git.SSH.maven插件 2.jenkins新建一个项目,配好git拉取代码.maven编译构建(gradle构建也行,这不重要) 3.SSH Server,填写需要传输的jar文 ...
- WPF 隧道路由事件
阅读本文前,请先了解 冒泡路由事件:http://www.cnblogs.com/andrew-blog/p/WPF_BubbledEvent.html 隧道路由事件的工作方式和冒泡路由事件相同,但方 ...
- 在线制作logo
logoko:http://www.logoko.com.cn/ markmarker:http://emblemmatic.org/markmaker/#/ logomaker:https://lo ...
- 将list列表中unicode类型的值转换为字符串类型
- 面试题思考:Java RMI与RPC,JMS的比较
RPC:(Remote Procedure Call) 被设计为在应用程序间通信的平台中立的方式,它不理会操作系统之间以及语言之间的差异. 支持多语言 RMI:(Remote Method Invo ...
- java基础---->数组的基础使用(一)
数组是一种效率最高的存储和随机访问对象引用序列的方式,我们今天来对数组做简单的介绍.手写瑶笺被雨淋,模糊点画费探寻,纵然灭却书中字,难灭情人一片心. 数组的简单使用 一.数组的赋值 String[] ...
- 遇到OutOfMemoryException异常了
遇到OutOfMemoryException异常了 2008-11-28 09:52 asp.net做的售后服务系统运行了快1年了,昨天在做全年数据导出的时候出现OutOfMemoryExceptio ...