python3实现将json对象存入Redis以及数据的导入导出
作者:angus_monroe 发布时间:2022-05-05 16:31:27
Redis数据类型
String:二进制安全,可以包含任何数据
Hash:一个键值(key=>value)对集合
List:简单的字符串列表
Set:string类型的无序集合
Zset:每个元素都会关联一个double类型的分数,redis通过分数来为集合中的成员进行从小到大的排序
Redis基本命令
Key: set, get, delete
Hash: hmset, hget, hdel
List: lpush, lindex
Set: sadd,smembers
Zset: zadd, zrange
具体用法可查看网上教程或官方文档或命令行提示
Redis持久化
Redis运行在内存中,但它同样提供了持久化机制
AOF:记录服务器执行的所有写操作命令,并在服务器启动时,通过重新执行这些命令来还原数据集
RDB:生成数据集的时间点快照
手动让Redis进行数据集保存:save
打开AOF功能:修改配置文件 appendonly yes
Labwork
针对数据库第十次上机作业进行一些总结
作业要求是将以下两个json对象存入Redis
var someexpert={
id:10000
realname: ‘expert-a'
organization:'BUAA'
}
var frameworks=[
‘vue',
‘react',
‘angular'
]
我在储存过程中全部是以python中的list形式转化为json进行储存的
初始化
在初始化前,我们首先需要在终端开启数据库,具体方法可以参考macOS上Redis的安装与测试
首先我们需要导入redis模块
import redis # 导入redis模块,通过python操作redis 也可以直接在redis主机的服务端操作缓存数据库
直接pip安装即可
pip3 install redis
接下来就是初始化数据库了,host是redis主机使用localhost即可,需要redis服务端和客户端都启动,redis默认端口是6379
def __init__(self):
self.host = 'localhost'
self.port = '6379'
self.r = redis.StrictRedis(host=self.host, port=self.port)
很多教程上写的是redis.Redis,然而官方是推荐使用redis.StrictRedis的
redis提供两个类Redis和StrictRedis用于实现Redis的命令,StrictRedis用于实现大部分官方的命令,并使用官方的语法和命令,Redis是StrictRedis的子类,用于向后兼容旧版本的redis-py。
redis基本命令
增加list
lpush(name,values)
在name对应的list中添加元素,每个新的元素都添加到列表的最左边,没有就新建
检查名字是否存在
exists(name)
检测redis的name是否存在,存在返回True,否则返回False
删除
delete(*names)
根据删除redis中的任意数据类型(string、hash、list、set、有序set)
列表长度
llen(name)
返回列表的长度。如果列表name不存在,则name被解释为一个空列表,返回0。如果name不是列表类型,返回一个错误。
获取指定列表指定区间元素
lrange(name, start, end)
返回列表中指定区间内的元素。
区间以偏移量start和end指定。 其中0表示列表的第一个元素,1表示列表的第二个元素,以此类推;也可以使用负数下标,以-1表示列表的最后一个元素,-2表示列表的倒数第二个元素,以此类推。
参考代码
# -*- coding=utf-8 -*-
__author__ = 'XJX'
__date__ = '2018.06.09'
"""
description:
将json对象存入Redis
"""
import json
import redis
class RedisTT(object):
def __init__(self):
self.host = 'localhost'
self.port = '6379'
self.r = redis.StrictRedis(host=self.host, port=self.port)
def insertRedis(self, keyName, jsonStr): # 存入到redis中
self.r.lpush(keyName, jsonStr)
def save1():
someexpert = {}
someexpert['id'] = 10000
someexpert['realname'] = 'expert-a'
someexpert['organization'] = 'BUAA'
if RedisTT().r.exists('someexpert'):
RedisTT().r.delete('someexpert') # 删除key为someexpert的键值对
RedisTT().insertRedis(keyName='someexpert', jsonStr=json.dumps(someexpert))
def save2():
frameworks = ['vue', 'react', 'angular']
if RedisTT().r.exists('frameworks'):
RedisTT().r.delete('frameworks') # 删除key为frameworks的键值对
RedisTT().insertRedis(keyName='frameworks', jsonStr=json.dumps(frameworks))
if __name__ == "__main__":
save1()
save2()
print(RedisTT().r.lrange('someexpert', 0, RedisTT().r.llen('someexpert')))
print(RedisTT().r.lrange('frameworks', 0, RedisTT().r.llen('frameworks')))
输出结果
导出rdb
安装redis-dump
gem install redis-dump -V
redis-dump导出数据
redis-dump –u 127.0.0.1:6379 > db.rdb
导出redis 默认数据库的数据,默认数据库为0,得到的db.rdb文件位于当前目录
如果指定15数据库的数据:
redis-dump –u 127.0.0.1:6379 –d 15 > db.rdb
导出得到的文件数据:
redis-load还原数据
将db.rdb文件上传到新的redis服务器上,进入到db.rdb目录,执行命令
< db.rdb redis-load;
或者
cat db.rdb | redis-load
如果导出时指定了数据库
cat db.rdb | redis-load –d 15
来源:https://blog.csdn.net/angus_monroe/article/details/80635187
猜你喜欢
- 写在前面:本节主要讲述一些基本的,常用的SQL语句,而非数据库方面的基本知识。数据库方面的知识留待以后再讲,现在就我们平常常用的一些SQL语
- 大家可以先参考python切片复制列表的知识点详解这篇内容,对知识点用法有个了解切片,即处理一个完整列表中部分数据。语法 变量[起始索引:终
- 前段时日微软(Microsoft)正式发布了.NET Core 2.0,在很多开发社区中反响不错。但还是有一些开发者发出了疑问,.NET C
- 需求:在django中,有时候我们需要在一个表单中设置多个按钮实现不同的功能。解决方法:为不同按钮添加不同name属性,然后再后台判断nam
- 之前写的单向链表和环形链表都只是单向的,只能单向遍历,不能根据后面的节点获取前面的节点,除非进行反转操作。双向链表每个节点都有两个指针,这两
- 打开VS2013 —> 工具 —> 选项 —> 环境 —> 字体和颜色 —> 纯文本(显示项中) —>
- python PIL 将数组值转成图片安装 PIL 包pip install pillow将二维数据转换成单通道图片from PIL imp
- 原文网址:gradio.app/sharing-you…1.分享演示share=True通过在方法中设置,可以轻松公开
- 数据库连接字符串的常见问题和解决方法:基本知识1:SQL Server数据库的身份验证方式,分windows验证,SQL Server验证两
- window.onload=function(){ pd(11);} function pd(number) { if(number>
- 在ASP编程中,身份认证可以说是常要用到的。但怎么样才能做到认证的安全呢?表单提交页面:sub.htm &
- 1、安装requests、xlrd、json、unittest库<1>pip 命令安装:pip install requests
- 系列一:图片格式介绍Gif格式特点透明性Gif是一种布尔透明类型,既它可以是全透明,也可以是全不透明,但是它并没有半透明(alpha 透明)
- A.截取从字符串左边开始N个字符 Declare @S1 varchar(100) Select @S1='http://www.x
- 介绍init 方法通常用在初始化一个类实例时候,但其实它不是实例化一个类的时候第一个被调用 的方法。当使用 Student(id, name
- 维护脚本一例,写得有点乱,只是作为一个实例,演示如何快速利用工具快速达到目的:应用到:shell与python数据交互、数据抓取,编码转换#
- 代码如下:arr = array(12,52,14,43,24,58,15,64,24,57,17,56,45)&nbs
- 本文介绍的是关于Python利用字典的默认行为的相关内容,分享出来供大家参考学习,下面来看看详细的介绍:典型代码1:from collect
- 为了实现Nao机器人与电脑端的TCP通信,于是研究了一下Python实现TCP通信,在网上也看到了很多例子,但大多都是在一台机器上验证。在两
- //获得视频文件的缩略图function getVideoCover($file,$time,$name) { &nb