轻量数据交换json,xml,ini
json语法:
object {string:value,...}
value string/number/object/array/true/false/null
array value
具体http://json.org/
举例:
{
"yuzusoft":
{
"birthYear": "2006",
"cross":[
"こぶいち",
"むりりん"
],
"country":"japan",
"job":"galgame",
"works":[
"天神乱漫",
"dracu-riot!"
]
},
"favorite":{
"birthYear":"2004",
"cross":["司田カズヒ","GT","なつめえり"],
"country":"japan",
"job":"galgame",
"works":[
"星空のメモリア",
"いろとりどりのセカイ",
"いろとりどりのヒカリ"
]
}
}
json只支持双引号
python的json模块
def load(fp, cls=None, object_hook=None, parse_float=None,
parse_int=None, parse_constant=None, object_pairs_hook=None, **kw)
#load从文件流中读
def loads(s, encoding=None, cls=None, object_hook=None, parse_float=None,
parse_int=None, parse_constant=None, object_pairs_hook=None, **kw)
#loads可以读作load string,从字符串读取,转成列表或字典
def dumps(obj, skipkeys=False, ensure_ascii=True, check_circular=True,
allow_nan=True, cls=None, indent=None, separators=None,
default=None, sort_keys=False, **kw)
#dumps可以理解为dump to string,对象转成字符串,对象可以是字典,列表等
#ensure_ascii 如果对象中有中文或日文,要定义ensure_ascii=False def dump(obj, fp, skipkeys=False, ensure_ascii=True, check_circular=True,
allow_nan=True, cls=None, indent=None, separators=None,
default=None, sort_keys=False, **kw)
#dump可以理解为dump to file
import json
temp={}
with open("Read.json","r",encoding="utf-8") as Rstream:
temp=json.loads(Rstream.read())
print(temp)
with open("Write.json","w",encoding="utf-8") as Wstream:
json.dump(temp,Wstream,ensure_ascii=False)
pickle模块
class TempClass(object):
def __init__(self):
self.show()
def show(self):
print("This is the text Class") temp=TempClass() with open("Read.pkl","wb") as Wstream:
pickle.dump(temp,Wstream)
with open("Read.pkl","rb") as Wstream:
temp2=pickle.load(Wstream)
print(temp2.show())
xml语法:
xml开头要有<?xml version="1.0" encoding="UTF-8" ?>
xml从一个根元素开始,就像linux的目录结构一样
xml的根节点,子节点,标签,属性,值
<?xml version="1.0" encoding="UTF-8" ?>
<galgame_company>
<yuzusoft>
<birthYear>2006</birthYear>
<cross_group>
<cross1>こぶいち</cross1>
<cross2>むりりん</cross2>
</cross_group>
<country>japan</country>
<job>galgame</job>
<works_group>
<works1>天神乱漫</works1>
<works1>dracu-riot!</works1>
</works_group>
</yuzusoft>
<favorite>
<birthYear>2004</birthYear>
<cross_group>
<cross1>司田カズヒ</cross1>
<cross2>GT</cross2>
<cross3>なつめえり</cross3>
</cross_group>
<country>japan</country>
<job>galgame</job>
<works_group>
<works>星空のメモリア</works>
<works>いろとりどりのセカイ</works>
<works>いろとりどりのヒカリ</works>
</works_group>
</favorite>
</galgame_company>
xml模块:
思路:首先要把xml从文件中解析出来,然后从找到根节点,然后就能往下读
修改:找到标签,修改属性,修改值,添加删除标签
创建:先创建根节点,然后再根节点上创建标签
import xml.etree.ElementTree as ET
xmlTree=ET.parse("Read.xml") #先解析文件
root=xmlTree.getroot() #拿到根节点
#遍历节点
for company in root:
print("-->",company.tag,company.attrib)
for item in company:
print("\t-->",item.tag)
configparse模块:
[client]
port = 3306
socket = /data/3306/mysql.sock [mysqld]
user = mysql
port = 3306
socket = /data/3306/mysql.sock
basedir = /application/mysql
datadir = /data/3306/data
查看
读(最重要):
import configparser
#定义configparse对象
config=configparser.ConfigParser()
config.read("my.cnf")
print(config.sections())
for section in config: #遍历section
print(section)
for key in config[section]: #遍历key
print("--->%s=%s"%(key,config[section][key]))
写:
#定义configparse对象
config=configparser.ConfigParser()
config['client']={"port":"","socket":"/data/3306/mysql.sock"}
config['mysqld']={"user":"mysql","port":3306,"socket":"/data/3306/mysql.sock"}
config['mysqldump']={"max_allowed_packet":"2M"}
with open("my,cnf","w") as Wtf:
config.write(Wtf)
轻量数据交换json,xml,ini的更多相关文章
- 数据交换格式XML和JSON对比
1.简介: XML:extensible markup language,一种类似于HTML的语言,他没有预先定义的标签,使用DTD(document type definition)文档类型定义来组 ...
- CYQ.Data 轻量数据层之路 优雅V1.4 现世 附API帮助文档(九)
继上一版本V1.3版本发布到现在,时隔N天了:[V1.3版本开源见:CYQ.Data 轻量数据层之路 华丽V1.3版本 框架开源] N天的时间,根据各路网友的反映及自身的想法,继续修改优化着本框架,力 ...
- CYQ.Data 轻量数据层之路 使用篇二曲 MAction 数据查询(十三)----002
原文链接:https://blog.csdn.net/cyq1162/article/details/53303390 前言说明: 本篇继续上一篇内容,本节介绍所有相关查询的使用. 主要内容提要: 1 ...
- CYQ.Data 轻量数据层之路 使用篇-MProc 存储过程与SQL 视频[最后一集] H (二十八)
2019独角兽企业重金招聘Python工程师标准>>> 说明: 本次录制主要为使用篇:CYQ.Data 轻量数据层之路 使用篇五曲 MProc 存储过程与SQL(十六) 的附加视 ...
- Java 常见数据交换格式——xml、json、yaml
目录 数据交换格式介绍 XML 使用DOM方式解析 使用SAX方式解析 使用DOM4J方式解析 使用JDOM方式解析 JSON 使用JSONObject方式将数据转换为JSON格式 利用JSONObj ...
- Web Scraper——轻量数据爬取利器
日常学习工作中,我们多多少少都会遇到一些数据爬取的需求,比如说写论文时要收集相关课题下的论文列表,运营活动时收集用户评价,竞品分析时收集友商数据. 当我们着手准备收集数据时,面对低效的复制黏贴工作,一 ...
- yii2解析非x-www-form-urlencoded类型的请求数据(json,xml)
组件配置添加: 'request' => [ 'parsers' => [ 'application/json' => 'yii\web\JsonParser', 'applicat ...
- 常用两种数据交换格式之XML和JSON的比较
目前,在web开发领域,主要的数据交换格式有XML和JSON,对于XML相信每一个web developer都不会感到陌生: 相比之下,JSON可能对于一些新步入开发领域的新手会感到有些陌生,也可能你 ...
- XML和JSON两种数据交换格式的比较
在web开发领域,主要的数据交换格式有XML和JSON,对于在 Ajax开发中,是选择XML还是JSON,一直存在着争议,个人还是比较倾向于JSON的.一般都输出Json不输出xml,原因就是因为 x ...
随机推荐
- 拔靴法--Bootstrap--R语言实现
拔靴法属于重复抽样(resampling)方法,与Monte Carlo相比,二者真实的母体不同.它是将已有的观察值作为母体重复抽样, 以求取原先资料不足二无法探讨的资料特性. 举个例子,假设x1,x ...
- block的语法
主要内容: 1. 开始使用block(Getting Started with Blocks) 2. block概念综述(Conceptual Overview) 3. 声明和创建block(Decl ...
- Sed是个好东西
今天遇到的源码使用了变态的宏,直接对参数进行宏处理,使得我的vim插件几乎全废,只能想办法将宏给替换进去. #!/bin/bash find . -type f -name '*.c' | xargs ...
- C++ 中的形参与返回值
函数调用时,形参对象和返回对象均采用引用方式进行(临时对象作为中介),当一个对象作为参数(非引用)被函数调用时,该对象会通过复制构造函数获得一个临时对象,该临时对象以引用方式传递给函数,简言之,函数会 ...
- oracle 存储过程的写法
create or replace procedure Getyc is v_id VARCHAR2(36); v_date VARCHAR2(4); begin declare begi ...
- [20150513]Linux远程登陆管理以及Vim的学习
Linux远程登陆管理以及Vim的学习 实现Linux远程管理 所需工具Xshell,Xshell是一个用于MS Windows平台的强大的SSH,TELNET,和RLOGIN终端仿真软件.它使得用户 ...
- Sqlite注入测试
测试了一个网站是Sqlite数据库,还装有安全狗,绕过了防护,找到Payload,写了一个Python脚本来跑表,这里总结一下: 取得sqlite数据库里所有的表名 查询table,type 段是't ...
- 将JZ2440的调试串口换成com2
众所周知JZ2440 V3很小巧,精致.今天单就JZ2440的串口来讨论一些问题.我们在用串口进行调试的时候,需要用JZ2440自带的一根USB线连接电脑USB口和开发板的USB-com1口.先来看一 ...
- 黑马程序员——JAVA基础之编码表
------- android培训.java培训.期待与您交流! --------- 字符编码 字符流的出现为了方便操作字符. 更重要是的加入了编码转换. 通过子类转换流来完成. • I ...
- js中的this指针(二)
在 js 中声明并定义一个函数后,除了定义时传入的形式参数,函数还会接收到 2 个附加的参数:this 和 arguments. this 指针的值取决于调用时的模式. 当这个函数被保存为对象的一个属 ...