Python day19 模块介绍3(sys,json,pickle,shelve,xml)
1.sys模块
import sys sys.path()#打印系统path
sys.version()#解释程序版本信息
sys.platform()#系统平台 sys.exit(0)#退出程序
command=sys.argv[1]#从程序外部获取参数
sys.stdout.write('#')#与print相同,区别是刷进缓存
# 例子
import time
for i in range(10):
sys.stdout.write('#')
time.sleep(1)
sys.stdout.flush() #把缓存刷进显示区
2.json模块
dic="{'name': 'alex'}"
f=open("hello",'w')
f.write(dic)
f.close()
f_read=open('hello','r')
c=f_read.read()
print(c)
print(eval(c))#eval,重新运算求出参数的内容
import json
dic={'name':'littlepage'}
doc=json.dumps(dic)#引号全部变成双引号,然后变成字符串
print(doc)
print(type(doc))
f=open('hellod','w')
f.write(doc)
f.close()
f_read=open('hellod','r')
data=json.loads(f_read.read())#json来把字符串变成字典
print(type(data))
f_read.close()
# 简写
f=open('helloddd','w')
dic={'name':'littlepage'}
doc=json.dump(dic,f)
3.pickle模块
import pickle#比json序列的类型更多
dic={'name':'littlepage','age':20,'gender':'male'}
j=pickle.dumps(dic)#转换成字节
print(type(j))
f=open('hello','wb')
pickle.dump(dic,f)
f.close()
f=open('hello','rb')
print(pickle.loads(f.read())) import pickle#比json序列的类型更多
dic={'name':'littlepage','age':20,'gender':'male'}
j=pickle.dumps(dic)#转换成字节
print(type(j))
f=open('hello','wb')
pickle.dump(dic,f)
f.close()
f=open('hello','rb')
print(pickle.loads(f.read()))
4.shelve
import shelve#操作简单,但是不常用
f=shelve.open(r'she')#将字典放入文本,f相当于一个字典,更加方便,文本存储的是一个键和范围
f['']={"name":'ss'}
f['']='sss'
f.close()
f=shelve.open(r'she')
print(f.get('')['name'])#可以进行获取
print(f.get(''))
f.close() import xml.etree.cElementTree as ET #xml模块,java语言不可替代,python逐渐在用json替代,但目前还在大量使用 tree=ET.parse("xml_lesson")#解析xml,xml是树形结构
root=tree.getroot()#获取根节点
print(root.tag)#打印根标签
5.xml
#遍历xml文档
for i in root:
for j in i:
print(j.tag,j.attrib)#tag标签,attribute属性
print(j.text)#值 #只遍历year节点
for node in root.iter('year'):
print(node.tag,node.text) #修改
for node in root.iter('year'):
new_year=int(node.text)+1
node.text=str(new_year)#设置文本内容
node.set("updated","yes")#设置属性,属性值 tree.write("xmltt.xml") #删除
for country in root.findall('country'):
rank=int(country.find('rank'.text))
Python day19 模块介绍3(sys,json,pickle,shelve,xml)的更多相关文章
- 学到了林海峰,武沛齐讲的Day22-完 os sys json pickle shelve XML re
__ file__ ===== 文件路径 os.path.dirname( 路径 )=======到上一层目录 os sys
- 模块 - json/pickle/shelve/xml/configparser
序列化: 序列化是指把内存里的数据类型转变成字符串,以使其能存储到硬盘或通过网络传输到远程,因为硬盘或网络传输时只能接受bytes. 为什么要序列化: 有种办法可以直接把内存数据(eg:10个列表,3 ...
- python 序列化及其相关模块(json,pickle,shelve,xml)详解
什么是序列化对象? 我们把对象(变量)从内存中编程可存储或传输的过程称之为序列化,在python中称为pickle,其他语言称之为serialization ,marshalling ,flatter ...
- python序列化及其相关模块(json,pickle,shelve,xml)详解
什么是序列化对象? 我们把对象(变量)从内存中编程可存储或传输的过程称之为序列化,在python中称为pickle,其他语言称之为serialization ,marshalling ,flatter ...
- Python学习笔记——基础篇【第六周】——json & pickle & shelve & xml处理模块
json & pickle 模块(序列化) json和pickle都是序列化内存数据到文件 json和pickle的区别是: json是所有语言通用的,但是只能序列化最基本的数据类型(字符串. ...
- Python全栈开发记录_第八篇(模块收尾工作 json & pickle & shelve & xml)
由于上一篇篇幅较大,留下的这一点内容就想在这里说一下,顺便有个小练习给大家一起玩玩,首先来学习json 和 pickle. 之前我们学习过用eval内置方法可以将一个字符串转成python对象,不过, ...
- python笔记-7(shutil/json/pickle/shelve/xml/configparser/hashlib模块)
一.shutil模块--高级的文件.文件夹.压缩包处理模块 1.通过句柄复制内容 shutil.copyfileobj(f1,f2)对文件的复制(通过句柄fdst/fsrc复制文件内容) 源码: Le ...
- python模块--json \ pickle \ shelve \ XML模块
一.json模块 之前学习过的eval内置方法可以将一个字符串转成一个python对象,不过eval方法时有局限性的,对于普通的数据类型,json.loads和eval都能用,但遇到特殊类型的时候,e ...
- 模块(序列化(json&pickle)+XML+requests)
一.序列化模块 Python中用于序列化的两个模块: json 跨平台跨语言的数据传输格式,用于[字符串]和 [python基本数据类型] 间进行转换 pickle python内置的数据 ...
随机推荐
- [LeetCode] 101. Symmetric Tree_ Easy tag: BFS
Given a binary tree, check whether it is a mirror of itself (ie, symmetric around its center). For e ...
- [LeetCode] 133. Clone Graph_ Medium tag: BFS, DFS
Clone an undirected graph. Each node in the graph contains a label and a list of its neighbors. OJ's ...
- AHB-Lite简介
AHB总线实现了简单的基于burst的传输,数据总线带宽可配置32-1024bit.可以实现简单的fixed pipeline在address/control phase和 data phase之间. ...
- Java的redis控制台-Jedis
jedis 源码地址:https://github.com/xetorthio/jedis
- MySQL从删库到跑路_高级(二)——自定义函数
作者:天山老妖S 链接:http://blog.51cto.com/9291927 一.自定义函数简介 自定义函数(user-defined function UDF)是一种对MySQL扩展的途径,其 ...
- 小试---EF5.0简介
简介 实体框架Entity Framework 是 ADO.NET 中的一组支持开发面向数据的软件应用程序的技术.是微软的一个ORM框架.简单的说就是把关系型数据库映射成面向对象模型. 一篇更加详细的 ...
- Openstack创建虚拟机 Restful api和RPC调用
Horizon前台界面用于接受用户的输入或动作(action),然后将这些参数构造成RESTful API(https://developer.openstack.org/api-ref/comput ...
- 浅谈为什么一个java源文件中只能有一个public类?
声明,本篇文章为转载 转载 http://blog.csdn.net/bareheadzzq/article/details/6562211 最近在一个java文件中实现了几个类,其中一个声明为pub ...
- java,url长链接生成短链接,短链接生成器,自定义字符串,对字符串md5混合KEY加密,根据短链接获得key值,不重复的随机数,不重复的随机字符串
java,url长链接生成短链接,短链接生成器,自定义字符串,对字符串md5混合KEY加密,根据短链接获得key值,不重复的随机数,不重复的随机字符串 package com.zdz.test; im ...
- 手撕vue-cli配置——utils.js篇
utils.js文件主要是用来处理各种css loader的,比如css-loader,less-loader等. //引入path模块 const path = require('path') // ...