python 序列化


1 什么叫序列化

在我们存储数据或网络传输数据时候,需要多我们对象进行处理,把对象处理成方便储存和网络传输的数据格式,这个过程叫做序列化

2 对象序列化有三种方式;

2.1 pickle 可以将python中任意数据类型转换成bytes并写入文件中,同样可以把文件中写好的bytes转化成python的相对应的数据,这个过程称为反序列化;

import pickle 
# 可以将对象写入文件中
#基本用法
#pickle.dump(obj,file,protocol=None,*,fix_imports=True)可以写入到文本中
#pickle.dump(obj,protocol=None,* fix_import=True) 一般用于正常的操作
# pickle.load(file, *, fix_imports=True, encoding="ASCII", errors="strict") 可以从文本加载
# pickle.loads(s, *, fix_imports=True, encoding="ASCII", errors="strict") 一般用于正常的操作
举例说明:
import pickle
class Person:
  def __init__(self, name, age):
      self.name = name
      self.age=age

  def login(self):
      pass
李明 = Person('李明',20)
王汪 = Person('王汪',19)
孙艳 = Person('孙艳',18)
# S1 = pickle.dumps(李明) # 序列化一个对象,将对象转换成bytes的形式
# S2 = pickle.loads(S1) # 进行反序列化,将bytes转换对象
li = [李明,王汪,孙艳]
with open('user',mode='ab') as f:
  pickle.dump(li, f) # 把列表转化butes,写入文件
with open('user',mode='rb') as f:
li= pickle.load(f) # 从文本中读取,将bytes的形式转化为列表
print(li)
for i in li:
  print(i)

简单注册和登录的例子:
class Account:
  def __init__(self,name,pwd):
      self.name=name
      self.pwd=pwd
def login():
    username=input('请输入用户:').strip()
    userpwd=input('请输入密码:').strip()
    with open('usernamelist',mode='rb') as f:
      while True:
      try:
        Account_User=pickle.load(f)
        if username==Account_User.name and userpwd==Account_User.pwd:
          print('登录成功')
          return True
      except:
          print('输入用户名和密码不对')
          return False
def regiest():
    while True:
    username=input("请输入用户名:").strip()
    with open('usernamelist',mode='rb') as f:
      while True:
        try:
        Account_User=pickle.load(f)
        except: EOFError
        if username==Account_User.name:
          print('用户名已存在,请重新选择用户名')
          break
        else:
        while True:
          userpwd=input("请输入用户密码:").strip()
          userpwd2=input('请再次输入密码:').strip()
          if userpwd==userpwd2:
            Account_User=Account(username,userpwd)
            with open('usernamelist',mode='ab') as f:
              pickle.dump(Account_User,f)
              return True
          else:
            print('二次密码输入不一致,请重试输入秘密')
def run():
while 1:
  opt_lst=[('登录', 'login'), ('注册', 'regiest'), ('退出', 'exit')]

  for index,lst in enumerate(opt_lst,1):
      print(lst[0],index)
  try:
    num=int(input('请输入对应序号:').strip())
  except: EOFError
  if hasattr(opt_lst[num-1][1],opt_lst[num - 1][1]):
      getattr(opt_lst[num-1][1],opt_lst[num-1][1])()
  if num==1: login()
  elif num==2: regiest()
  else: break
  # print(opt_lst[num-1][1])
  # # if hasattr(opt_lst[num-1][1],opt_lst[num-1][1]):
  # getattr(opt_lst[num-1][1],opt_lst[num-1][1])()

if __name__=='__main__':
  run()


   
 

2.2 shelve 简单另类一种序列化方法,可以作为小型数据库使用

2.3 json 将python中常见的字典,列表转换字符,是目前前后端数据交换使用频率最高一种数据格式

import json

# json.dumps()
# 把字典转换成json字符串
# json.loads()
# 把json字符串转化成字典
# json.dump()
# 把字典转换成json字符串.写入到文件
# json.load()
# 把文件中的json字符串读取.转化成字典
dic = {'输出':'鲁班','坦克':'项羽','法师':'安琪拉了'}
gg = json.dumps(dic,ensure_ascii=False) #ensure_ascii=False,是能够看到中文
print(gg)#{"输出": "鲁班", "坦克": "项羽", "法师": "安琪拉了"}
print(type(gg))#<class 'str'>

bb = '{"输出": "鲁班", "坦克": "项羽", "法师": "安琪拉"}'
gg = json.loads(bb)
print(gg)#{'输出': '鲁班', '坦克': '项羽', '法师': '安琪拉'}
print(type(gg))#<class 'dict'>
gg = json.dump(dic,open('json.data','w',encoding='utf-8'),indent=4,ensure_ascii=False)
print(gg)#None # ensure_ascii=False 保存到文件的时候不使用ascii 编码
print(type(gg))#<class 'NoneType'>

dd = json.load(open('json.data','r',encoding='utf-8'))
print(type(dd))#<class 'dict'>
print(dd)#{'输出': '鲁班', '坦克': '项羽', '法师': '安琪拉了'
#将一个类的属性保存到json中
class Person:
  def __init__(self,name,func):
      self.name = name
      self.func = func


# ensure_ascii=True 保存到文件的时候不使用ascii 编码
a = Person('鲁班','射手')
# 方案1,通过类的特殊方法
dd = json.dumps(a.__dict__,ensure_ascii=False)
print(dd)

# 方案2,通过自己建立转换模板
def gg(obj):
  print('哈哈')
  return {'kk':obj.name,'fn':obj.func}#
hh = json.dumps(a,default=gg,ensure_ascii=False) #{"kk": "鲁班", "fn": "射手"}
print(hh)
# 将jsonz字符串转换为对象
def gg(dic):
  return Person(dic['kk'],dic['fn'])
a = '{"kk": "鲁班", "fn": "射手"}'
print(json.loads(a,object_hook=gg))
hh = json.loads(a,object_hook=gg)
print(hh.name)

default = 把对象转化成字典. 需要自己写转换过程 object_hook = 把字典转化成对象. 需要自己写转换过程

python---序列化小结的更多相关文章

  1. Python 学习小结

    python 学习小结 python 简明教程 1.python 文件 #!/etc/bin/python #coding=utf-8 2.main()函数 if __name__ == '__mai ...

  2. python 序列化之JSON和pickle详解

    JSON模块 JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式.它基于ECMAScript的一个子集. JSON采用完全独立于语言的文本格式,但是也使用了类 ...

  3. Python序列化和反序列化

    Python序列化和反序列化 通过将对象序列化可以将其存储在变量或者文件中,可以保存当时对象的状态,实现其生命周期的延长.并且需要时可以再次将这个对象读取出来.Python中有几个常用模块可实现这一功 ...

  4. Java序列化小结

    title: Java序列化小结 date: 2017-05-06 20:07:59 tags: 序列化 categories: Java基础 --- Java序列化就是将一个对象转化成一串二进制表示 ...

  5. python序列化pickle/cPickle

    一.pickle/Cpickle简介 Python序列化的概念很简单.内存里面有一个数据结构,你希望将它保存下来,重用,或者发送给其他人.你会怎么做?这取决于你想要怎么保存,怎么重用,发送给谁.很多游 ...

  6. python序列化与反序列

    python序列化与反序列 在python中提供了两个模块可进行序列化.分别是pickle和json.他们两者的功能都差不多,dumps和dump都是进行序列化,而loads和load则是反序列化. ...

  7. Python 序列化pickle/cPickle模块整理

    Python序列化的概念很简单.内存里面有一个数据结构,你希望将它保存下来,重用,或者发送给其他人.你会怎么做?这取决于你想要怎么保存,怎么重用,发送给谁.很多游戏允许你在退出的时候保存进度,然后你再 ...

  8. 学习笔记:Python序列化常用工具及性能对比

    什么叫序列化?简单来讲就是将内存中的变量数据转而存储到磁盘上或是通过网络传输到远程. 反序列化是指:把变量数据从序列化的对象重新读到内存里. 下面我们一起来看看,python里面序列化常用的json. ...

  9. Python 序列化 pickle/cPickle模块

    Python 序列化 pickle/cPickle模块 2013-10-17 Posted by yeho Python序列化的概念很简单.内存里面有一个数据结构,你希望将它保存下来,重用,或者发送给 ...

  10. Python 序列化与反序列化

    序列化是为了将内存中的字典.列表.集合以及各种对象,保存到一个文件中(字节流).而反序列化是将字节流转化回原始的对象的一个过程. json库 序列化:json.dumps() 反序列化:json.lo ...

随机推荐

  1. PGF 概率生成函数 Probability generating function

    Probability Mass Function 离散随机变量的分布函数PMF 目录 随机结构举例 two classical combinatorial distributions PGF Pro ...

  2. 最新 umi4-max 如何使用 webpack5 联邦模块

    新项目用 umi4-max 搭建,部分功能想要使用其他项目的功能,不想重新开发,想到了使用 webpack5 的联邦模块,可以直接引用其他项目代码来实现共享代码. 理想很美好,现实很残酷.直接按照 w ...

  3. Java面试——Linux

    一.如果知道一个文件名称,怎么查这个文件在 Linux下的哪个目录,如:要查找 tnsnames.ora文件 1 find / -name tnsnames.ora 2 #还可以用locate 来查找 ...

  4. Linux防火墙与端口操作命令

    CentOS 7系统 目录 1. 防火墙操作命令 2. 端口操作命令 3. CentOS 7 下安装firewall 1. 防火墙操作命令 序号 作用 命令 1 查看防火墙状态 systemctl s ...

  5. PHP微信三方平台-代公众号发送消息模板

    1.微信三方平台代公众号实现业务接口API文档地址: https://developers.weixin.qq.com/doc/oplatform/Third-party_Platforms/Offi ...

  6. 四月二十五号java基础知识

    1.注意:无论哪个构造方法,在创建文件输入输出流时都可能银给出的文件名不对.路径不对文件的属性不对等,不能打开文件而造成错误,此时系统会抛出FileNotFoundException异常执行read( ...

  7. Nvidia GPU热迁移-Singularity

    1 背景 在GPU虚拟化和池化的加持下,可以显著提高集群的GPU利用率,同时也可以较好地实现弹性伸缩.但有时会遇到需要GPU资源再分配的场景,此时亟需集群拥有GPU任务热迁移的能力.举个简单的例子,比 ...

  8. redis 基于 漏斗算法 实现对 api 的限流

    漏斗算法 漏桶算法的原理: 漏桶有一定的容量,给漏桶注水,当单位时间内注入水量大于流出水量,漏桶内积累的水就会越来越多,直到溢出. 就好比大批量请求访问nginx相当于注水,nginx根据配置按照固定 ...

  9. 「学习笔记」重修 FHQ-treap

    无旋 treap 的操作方式使得它天生支持维护序列.可持久化等特性. 无旋 treap 又称分裂合并 treap.它仅有两种核心操作,即为 分裂 与 合并.通过这两种操作,在很多情况下可以比旋转 tr ...

  10. App复杂动画实现——Rive保姆级教程

    作者:京东物流 沈明亮 在App开发过程中,如果想实现动画效果,可以粗略分为两种方式.一种是直接用代码编写,像平移.旋转等简单的动画效果,都可以这么干,如果稍微复杂点,就会对开发工程师的数学功底.图形 ...