json,pickle模块
        1. 什么是序列化
            序列化指的是将内存中的数据类型转换成一种中间格式,该格式可以用来存到硬盘中或者基于网络传输
        2. 为何要序列化
            1. 持久化(把某一时刻程序的运行状态永久保存下来)
            2. 基于网络传输,可以扩平台交互数据
        3. 如何序列化
            json:(t模式文本)rt,wt,at          写进硬盘 格式任意 读一定要满足json的格式

json.dump([1,2],open('a.txt','wt',encoding='utf-8',),ensure_ascii=False)默认为True


优点:兼容所有语言,可以扩平台交互数据
                缺点:不能支持所有的python数据类型
            pickle:(b模式二进制读写)rb,wb,ab


                优点:可以支持所有的python数据类型
                缺点:不能跨平台
           json.dumps(数据类型)  json.loads(json格式的字符串)
           json.dump(数据类型,文件对象)   json.load(文件对象)
shelve模块(pickle底层功能的封装)
 info={'name':'egon','age':18,'hobby':['piao','smoking','drinking']}
 存
 f=shelve.open(r'sheve.txt') 不用指定模式可读可写
 f['st']=info
 f.close()
 取
 f=shelve.open(r'sheve.txt')
 print(f['st']['name'])
 f.close()
 改
 f=shelve.open(r'sheve.txt',writeback=True) #改:全部重新写到硬盘
 f['st']['name']='alex'
 f.close()
xml模块(中间格式) 解析文件
 格式:
 <data>
  <country name="Liechtenstein">
   <rank updated="yes">2</rank>
   <year>2008</year>
   <gdppc>141100</gdppc>
   <neighbor name="Austria" direction="E"/>
   <neighbor name="Switzerland" direction="W"/>
  </country>
 </data>
   就像字典:date={Liechtenstein:{....}}
 
 import xml.etree.ElementTree as ET 
  tree = ET.parse("xmltest.xml") #整棵树(加载解析文件)
  root = tree.getroot()          #先拿树根(节点)例如root节点<peple age='18'>wd</people>   root.tag,.attrib,.text
  查
  root.iter('year')          #全文搜索
  root.find('country')       #当前的节点的下一层找(当前为根节点),只找一个
  root.findall('country')    #当前的节点的下一层找(当前为根节点),找所有
  
   举例res=root.find('country') #country节点 
    nh=res.find('year')   #从country节点开始找下层的year,没有返回None 
  改
   1.找到要改的
   2.改
   3.tree.write('a.xml',#encoding="utf-8",xml_declaration=True) #把整棵树wt覆盖写回
  增
   ele=ET.Element('egon')#增加节点
   ele.attrib={'nb':'yes'}#属性
   ele.text='非常帅'#属性
   
   节点.append(ele) #把节点添加进节点ele
    .remove(ele) #
    
  建整棵树
   先拿个节点作为根:ele=ET.Element('egon')
        tree=ET.ElementTree(ele)
   再创建其他子节点:
       a=ET.Element('egon1')    #a表示节点,egon1是节点的(a.tag)名字
       a.text=
       a.attrib=
  b=ET.subElement('父节点',‘子节点’,attrib= ,text=?)
       ele.append(a)
   最后保存
     tree.write('路径文件名')#可以指定编码 还有这个头文件申明就像codeing:utf-8一个道理
  图

(常用)xml-pickle-shevel-json模块的更多相关文章

  1. Python开发之序列化与反序列化:pickle、json模块使用详解

    1 引言 在日常开发中,所有的对象都是存储在内存当中,尤其是像python这样的坚持一切接对象的高级程序设计语言,一旦关机,在写在内存中的数据都将不复存在.另一方面,存储在内存够中的对象由于编程语言. ...

  2. Python序列化-pickle和json模块

    Python的“file-like object“就是一种鸭子类型.对真正的文件对象,它有一个read()方法,返回其内容.但是,许多对象,只要有read()方法,都被视为“file-like obj ...

  3. Python中的序列化以及pickle和json模块介绍

    Python中的序列化指的是在程序运行期间,变量都是在内存中保存着的,如果我们想保留一些运行中的变量值,就可以使用序列化操作把变量内容从内存保存到磁盘中,在Python中这个操作叫pickling,等 ...

  4. pickle和json模块

    json模块 json模块是实现序列化和反序列化的,主要用户不同程序之间的数据交换,首先来看一下: dumps()序列化 import json '''json模块是实现序列化和反序列话功能的''' ...

  5. pytho中pickle、json模块

    pickle & json 模块 json,用于字符串 和 python数据类型间进行转换 pickle,用于python特有的类型 和 python的数据类型间进行转换 json模块提供了四 ...

  6. Learning-Python【20】:Python常用模块(3)—— shelve、pickle、json、xml、configparser

    什么是序列化/反序列化? 序列化就是将内存中的数据结构转换成一种中间格式存储到硬盘或者基于网络传输,反序列化就是硬盘中或者网络中传来的一种数据格式转换成内存中数据结构 为什么要有序列化/反序列化? 1 ...

  7. os常用模块,json,pickle,shelve模块,正则表达式(实现运算符分离),logging模块,配置模块,路径叠加,哈希算法

    一.os常用模块 显示当前工作目录 print(os.getcwd()) 返回上一层目录 os.chdir("..") 创建文件包 os.makedirs('python2/bin ...

  8. Python 常用模块(2) 序列化(pickle,shelve,json,configpaser)

    主要内容: 一. 序列化概述 二. pickle模块 三. shelve模块 四. json模块(重点!) 五. configpaser模块 一. 序列化概述1. 序列化: 将字典,列表等内容转换成一 ...

  9. python 常用模块(一): os模块,序列化模块(json模块 pickle模块 )

    1.os模块 2.序列化模块:(1)json模块 和 pickle模块 一.os模块 os.path.abspath: (1)把路径中不符合规范的/改成操作系统默认的格式 import os path ...

  10. 第九节:os、sys、json、pickle、shelve模块

    OS模块: os.getcwd()获取当前路径os.chdir()改变目录os.curdir返回当前目录os.pardir()父目录os.makedirs('a/b/c')创建多层目录os.remov ...

随机推荐

  1. PHPMYWIND4.6.6前台Refer头注入+后台另类getshell分析

    下载链接 https://share.weiyun.com/b060b59eaa564d729a9347a580b7e4f2 Refer头注入 全局过滤函数如下 function _RunMagicQ ...

  2. Oracle了解(一)

    通常所说的Oracle数据库服务器由一个数据库和至少一个数据库实例组成. 数据库实例是由系统后台进程和分配的内存区域构成 实例你是提供服务的进程,数据库是存放的数据. 数据库是存储数据的文件 数据库实 ...

  3. ext Ext.grid.去除右边空白

    1.当Scroll没有显示时,Ext.grid右边会显示一个空白间隔. 2.解决办法<View> <ext:GridView ForceFit="true" Sc ...

  4. 【BZOJ】2286: [Sdoi2011]消耗战 虚树+DP

    [题意]给定n个点的带边权树,每次询问给定ki个特殊点,求隔离点1和特殊点的最小代价.n<=250000,Σki<=500000. [算法]虚树+DP [题解]考虑普通树上的dp,设f[x ...

  5. Python之线程 1 - 线程基本概念

    一 背景知识 1.进程 2.有了进程为什么还要线程 3.线程的出现 二 线程和进程的关系 三 线程的特点 四 线程的实际应用场景 五 内存中的线程 六 用户级线程和内核级线程(了解) 1.用户级线程 ...

  6. luogu P3312 [SDOI2014]数表

    传送门 我们看要求的东西\[\sum_{i=1}^{n}\sum_{j=1}^{m}[\sigma(gcd(i,j))\le a]\sigma(gcd(i,j))\] 然而\(\le a\)比较烦,可 ...

  7. 电脑丢失api-ms-win-core-libraryloader-|1-1-1.dll怎么办

    电脑从win7升级到win10,到98%的时候提示说丢失.dll,如图,我是64位系统,怎么解决这个问题呢?在脚本之家下载了 放到system32中也没有用,在线等,谢谢! 用C:\Windows\S ...

  8. Kaldi的关键词搜索(Keyword Search,KWS)

    本文简单地介绍了KWS的原理--为Lattice中每个词生成索引并进行搜索:介绍了如何处理OOV--替补(Proxy,词典内对OOV的替补)关键词技术:介绍了KWS的语料库格式:介绍了KWS在Kald ...

  9. Java NIO之Selector(选择器)

    历史回顾: Java NIO 概览 Java NIO 之 Buffer(缓冲区) Java NIO 之 Channel(通道) 其他高赞文章: 面试中关于Redis的问题看这篇就够了 一文轻松搞懂re ...

  10. JDK源码笔记--Object

    public final native Class<?> getClass(); public native int hashCode(); public boolean equals(O ...