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. python爬取今日的bing壁纸

    #!/usr/bin/python #你要的文件夹是 E://pics// ps:没有的话帮你建一个 import requests import os from datetime import da ...

  2. ArchLinux 作业系统安装教程

    如果你能看到此文,想必你一定玩过不少的发行商发行的 Linux 作业系统或者听说过很多发行商发行的 Linux 作业系统.如果你玩过不少的 Linux 作业系统,对于安装系统可谓是轻车熟路,就是闭着眼 ...

  3. MyBatisPlus---DQL编程控制

    MP将书写复杂的SQL查询条件进行了封装,使用编程的形式完成查询条件的组合. 一.条件查询 package com.itheima; import com.baomidou.mybatisplus.c ...

  4. 【JS基础】ES6模块系统

    export export 导出方式有两种,命名导出和默认导出. 命名导出还是默认导出都是都导出模块中内容的一种方式,可以混合使用. 个人理解:默认导出其实是导出了default别名变量. 一个模块只 ...

  5. Spring 的核心组件详解

    Spring 总共有十几个组件,但是真正核心的组件只有三个:Core.Context 和 Bean.它们构建起了整个 Spring的骨骼架构,没有它们就不可能有 AOP.Web 等上层的特性功能. 一 ...

  6. jQ的工具类方法

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  7. 企业实践 | 国产操作系统之光? 银河麒麟KylinOS-V10(SP3)高级服务器操作系统基础安装篇

    [点击 关注「 全栈工程师修炼指南」公众号 ] 设为「️ 星标」带你从基础入门 到 全栈实践 再到 放弃学习! 涉及 网络安全运维.应用开发.物联网IOT.学习路径 .个人感悟 等知识分享. 希望各位 ...

  8. AI工具导航

    .xe-comment-entry img { float: left; display: block; background: rgba(136, 136, 136, 0.15); margin-r ...

  9. [Android]ADB调试: SecurityException: Injecting to another application requires INJECT_EVENTS permission

    问题描述 使用ADB工具调试安卓设备时报此错误: C:\Users\Johnny>adb shell input text "Hello" java.lang.Securit ...

  10. 通过命令快速找到python的路径

    查询Python 首先我们需要知道Python安装路径,可以在命令行中逐行执行下面代码 python3 import sys sys.executable