简单数据交换格式

CSV:

一般用  open()  函数和字符串拆分  split()  方法,但python有内置的csv模块

读:

import csv

with open(r"C:\User\Jery\Desktop\测试.csv", 'r', encoding='utf-8')as rf:
r = csv.reader(rf, dialect=csv.excel)
for row in r:
print("|".join(row))

写:

import csv

with open(r"C:\User\Jery\Desktop\测试.csv", 'r', encoding='utf-8')as rf:
r = csv.reader(rf, dialect=csv.excel)
with open(r"C:\User\Jery\Desktop\测试_副本.csv", 'w', encoding='utf-8')as wf:
w = csv.writer(wf)
for row in r:
# print("|".join(row))
w.writerow(row)

参数newline设置为空字符,就是在写入一行数据时不再加换行符,默认writer写入数据是会加换行符。

XML

XML主要由标签构成,主要分为:

声明:如:<?xml version=”1.0” encoding=”UTF-8”?>

根元素:根元素只有一个

子元素:若为空,写法可以为<node/>

属性:<node id=”1”>

命名空间:<node xmlns:***=”***”>

限定名:特定元素或属性,如<node:body>

解析:SAX解析和DOM解析:

SAX基于事件驱动,遇到文档标签就会触发相应事件,只能读文档,解析速度快。

DOM基于文档对象,将文档作为树状结构分析,会获取节点内容及属性,一次性将文档读入内存,能够修改文档。

eg:

import xml.etree.ElementTree as ET

tree = ET.parse(r'C:\Users\Jery\Desktop\测试.xml')
root = tree.getroot()
print(type(tree))
print(root.tag)
for index,child in enumerate(root):
print('第{}个{}元素,属性{}'.format(index,child.tag,child.attrib))
for i,child_child in enumerate(child):
print('---标签{},内容{}---'.format(child_child.tag,child_child))

XPath:

import requests
from lxml import etree # 按tab键自动提示 url = ''
res = requests.get(url)
# 把网页变成xpath结构
res_xpath = etree.HTML(res.text)
type(res_xpath) # /text()提取文字,此处提取是绝对路径
res_xpath.xpath('/html/head/title/text()') # //提取任意独一无二的子节点,//后面是标签名字
res_xpath.xpath('//a/text()') # 单引号双引号嵌套使用
res_xpath.xpath('//a[@class=“menu”and @href="category"]/text()') # 使用[]指定提取第几个,前面用*效率低,全局筛选,最好用更细的标签
res_xpath.xpath('*[id="categoryList"]/li[1]//div[@class="video_title"]/text()') # 提取属性,提取链接,"."相对路径
for li in res_xpath.xpath('//ul[@id="categoryList"]/li'):
li.xpath('.//div/a[1]/@href') # 拼成链接
for li in res_xpath.xpath('//ul[@id="categoryList"]/li'):
print('http://www.pearvideo.com/'+li.xpath('./div/a/Chref')[0])

JSON:

Json文档结构:

对象:名称:值 对集合——对应python字典

数组:一连串元素集合——对应python列表/元组

解码:

loads()将JSON字符串进行解码,返回python数据

load()读取文件或流,对JSON数据进行解码,返回python数据

eg:

import json

j = r'{"name":"Jery","sex":"男","age":18,"array":[1,2,3]}'
j_dict = json.loads(j)
print(type(j_dict))
print(j_dict['name'])
print(j_dict['array'])
with open(r'C:\Users\Jery\Desktop\a.json','r',encoding='UTF-8')as f:
data = json.load(f)
print(type(data))
print(data)

配置文件ini

Windows系统配置文件ini:

结构:

节:包括若干个配置项。如:[Startup]

配置项:由键值对构成,默认等号隔开。如:RequireOS = Windows10

注释:单独占一行,默认用分号隔开。如:;Startup节

配置文件的读取:eg

import configparser

config = configparser.ConfigParser()  # 创建解析器对象
config.read(r'C:\Users\Jery\Desktop\xml.ini', encoding='gbk') # 读取并解析,编码格式依文件而定
print(config.sections()) # 返回所有节
print(config.options('desp')) # 返回desp节下配置项名
print(config['desp']['Pos']) # desp节下的Pos项值

配置文件的写入:

import configparser

config = configparser.ConfigParser()
config.read(r'C:\Users\Jery\Desktop\xml.ini',encoding='gbk')
config['desp']['Newtext'] = 'hello ini'
config.add_section('New_Section') # 添加节
config.set('New_Section','name','Jery') # 添加配置项
with open(r'C:\Users\Jery\Desktop\xml.ini','w')as fw: # 开始写入
config.write(fw)

Python——数据交换格式简要的更多相关文章

  1. python开发_json_一种轻量级的数据交换格式

    以下是我做的对于python中json模块的demo 运行效果: Python 3.3.2 (v3.3.2:d047928ae3f6, May 16 2013, 00:03:43) [MSC v.16 ...

  2. json 数据交换格式与java

    http://wiki.mbalib.com/wiki/数据交换 数据交换是指为了满足不同信息系统之间数据资源的共享需要,依据一定的原则,采取相应的技术,实现不同信息系统之间数据资源共享的过程. 数据 ...

  3. 常用两种数据交换格式之XML和JSON的比较

    目前,在web开发领域,主要的数据交换格式有XML和JSON,对于XML相信每一个web developer都不会感到陌生: 相比之下,JSON可能对于一些新步入开发领域的新手会感到有些陌生,也可能你 ...

  4. XML和JSON两种数据交换格式的比较

    在web开发领域,主要的数据交换格式有XML和JSON,对于在 Ajax开发中,是选择XML还是JSON,一直存在着争议,个人还是比较倾向于JSON的.一般都输出Json不输出xml,原因就是因为 x ...

  5. JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式

    JSON JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式. 它基于JavaScript(Standard ECMA-262 3rd Edition - D ...

  6. Ajax-06 Ajax数据交换格式

    1.数据交换格式 服务端返回的数据,在本质上都是字符串,只是原生Ajax 或jQuery Ajax将这些字符串转换为容易理解的各种常用格式. a. Text 文本字符串 b.  XML JavaScr ...

  7. json:js和jquery中轻量级数据交换格式

    JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式.它基于ECMAScript的一个子集. JSON采用完全独立于语言的文本格式,但是也使用了类似于C语言家族 ...

  8. 数据交换格式XML和JSON对比

    1.简介: XML:extensible markup language,一种类似于HTML的语言,他没有预先定义的标签,使用DTD(document type definition)文档类型定义来组 ...

  9. 2016/4/2 json:js和jquery中轻量级数据交换格式 例: 窗口弹出 popwindow

    JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式.它基于ECMAScript的一个子集. JSON采用完全独立于语言的文本格式,但是也使用了类似于C语言家族 ...

随机推荐

  1. mybatis思维导图(一)

    写在前面 与hibernate相比,我无疑更喜欢mybatis,就因为我觉得它真的好用,哈哈.它简单上手和掌握:sql语句和代码分开,方便统一管理和优化:当然缺点也有:sql工作量很大,尤其是字段多. ...

  2. 常用工具类——StringUtils

    /* * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreem ...

  3. Jsp 的映射

    Jsp 的映射 Jsp 的映射 Jsp最佳实践 不管是jsp还是Servlet,虽然都可以开发动态Web资源,但是这两门 技术的各自特点,在长期的软件实践中,人们逐渐的把servlet作为 web应用 ...

  4. SNP芯片的原理

    Illumina的SNP芯片原理 Illumina的SNP生物芯片的优势在于: 第1,它的检测通量很大,一次可以检测几十万到几百万个SNP位点 第2,它的检测准确性很高,它的准确性可以达到99.9%以 ...

  5. SQL2000中创建作业(定时查询,更新)(转)

    出处:http://blog.csdn.net/xys_777/article/details/5683413 SQL2000中创建作业(定时查询,更新)企业管理器 --管理 --SQL Server ...

  6. 编写高质量代码改善C#程序的157个建议——建议95:避免在构造方法中调用虚成员

    建议95:避免在构造方法中调用虚成员 在构造方法中调用虚方法会带来一些意想不到的错误,虽然这种方法不常见,但还是需要注意这类陷阱. static void Main() { American amer ...

  7. javascript高级程序设计读书笔记----面向对象的程序设计

        创建对象   工厂模式 function createPerson(name, age, job){ var o = new Object(); o.name = name; o.age = ...

  8. C++ 内敛函数

    在主调函数调用函数时,先将现场压入栈以保存现场-转去执行被掉函数-返回主调函数.现场出栈以恢复现场-继续往下执行. 为了减少函数调用的成本,特别是对于小型函数,C++提供了内敛函数(inline).C ...

  9. opencv——播放视频

    #include "stdafx.h" #include <opencv2\opencv.hpp> #include <iostream> #include ...

  10. Centos 7 修改默认的运行级别

    Runlevel System State 0 Halt the system 1 Single user mode 2 Basic multi user mode 3 Multi user mode ...