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内置的数据 ...
随机推荐
- VS2013发布网站详细步骤
以下是我发布网站的时候,搜索到的可以使用的办法,同样适用于vs2013(已经尝试). 1.打开你的VS2012网站项目,右键点击项目>菜单中 重新生成一下网站项目:再次点击右键>发布: V ...
- WPF学习笔记-用Expression Design制作矢量图然后导出为XAML
WPF学习笔记-用Expression Design制作矢量图然后导出为XAML 第一次用Windows live writer写东西,感觉不错,哈哈~~ 1.在白纸上完全凭感觉,想象来画图难度很大, ...
- Object-C-NSString
NSString *info=@"Hello world"; NSString *info=[[NSString alloc]initWithFormat:@"my na ...
- 最近整理出了有关大数据,微服务,分布式,Java,Python,Web前端,产品运营,交互等1.7G的学习资料,有视频教程,源码,课件,工具,面试题等等。这里将珍藏多年的资源免费分享给各位小伙伴们
大数据,微服务,分布式,Java,Python,Web前端,产品运营,交互 领取方式在篇尾!!! 基础篇.互联网架构,高级程序员必备视频,Linux系统.JVM.大型分布式电商项目实战视频...... ...
- [转]Mac Appium环境安装
原文:https://blog.csdn.net/dongqiushan/article/details/53326518 1.安装JDK; 2.安装Android SDK; 3.安装brew; 4. ...
- HDFS文件操作
hadoop装好后,文件系统中没有任何目录与文件 1. 创建文件夹 hadoop fs -mkdir -p /hkx/learn 参数-p表示递归创建文件夹 2. 浏览文件 hadoop fs -ls ...
- sublime工具安装完成后使用Emmet加快前端页面的开发速度
sublime的安装这里就不介绍了,很多人看到有些人在使用sublime时使用了一些快捷键非常快速的搭建一个简单的html,简单的结构就打起来了.不需要手动一个标签一个标签写. 其实是他们安装了Emm ...
- Python入门之实现简单的购物车功能
Talk is cheap,Let's do this! product_list = [ ['Iphone7 Plus', 6500], ['Iphone8 ', 8200], ['MacBook ...
- Redis的两种持久化方式-快照持久化(RDB)和AOF持久化
Redis为了内部数据的安全考虑,会把本身的数据以文件形式保存到硬盘中一份,在服务器重启之后会自动把硬盘的数据恢复到内存(redis)的里边,数据保存到硬盘的过程就称为“持久化”效果. redis有两 ...
- wireshark不支持抓localhost/127.0.0.1的包解决方法
有些时候,测试网络应用时,为了开发方便,我们会在本机同时开启客户端和测试端,对于第三方的库来说,因为不能debug,可能需要通过抓包进行分析,今天用wireshark根据端口抓包的时候,发现怎么都下不 ...