python存储xml格式数据
例子
import xml.dom.minidom # 在内存中创建一个空的文档
doc = xml.dom.minidom.Document()
# 创建一个根节点Managers对象
root = doc.createElement('Managers')
# 设置根节点的属性
root.setAttribute('company', 'xx科技')
root.setAttribute('address', '科技软件园')
# 将根节点添加到文档对象中
doc.appendChild(root) managerList = [{'name':'joy', 'age':24, 'sex':'女'},
{'name':'tom', 'age':20, 'sex':'男'},
{'name':'ruby', 'age':30, 'sex':'女'}
] for i in managerList:
nodeManager = doc.createElement('Manager')
nodeName = doc.createElement('name')
# 给叶子节点name设置一个文本节点,用于显示玩文本内容
nodeName.appendChild(doc.createTextNode(str(i['name']))) nodeAge = doc.createElement('Age')
nodeAge.appendChild(doc.createTextNode(str(i['age']))) nodeSex = doc.createElement('sex')
nodeSex.appendChild(doc.createTextNode(str(i['sex']))) # 将各子叶节点添加到父节点Manager中,
# 最后将Manager添加到根节点Managers中
nodeManager.appendChild(nodeName)
nodeManager.appendChild(nodeAge)
nodeManager.appendChild(nodeSex)
root.appendChild(nodeManager) # 开始写xml文件
fp = open('Manager.xml', 'w')
doc.writexml(fp, indent='\t', addindent='\t', newl='\n', encoding='utf-8')
实战获取双色球开奖数据,并 保存为xml格式
# -*- coding: UTF-8 -*-
import requests
import parsel
import xml.dom.minidom
import datetime #base_url='http://www.cwl.gov.cn/cwl_admin/kjxx/findDrawNotice?name=ssq&issueCount=&issueStart=&issueEnd=&dayStart=2003-01-01&dayEnd=2021-02-19&pageNo=14'
base_url='https://kaijiang.78500.cn/ssq/' header={
'user-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/88.0.4324.150 Safari/537.36',
'referer': 'https://kaijiang.78500.cn/ssq/'
} formdata={
'startqi':'',
'endqi':'',
'year':'',
'action': 'years' } # 在内存中创建一个空的文档
doc = xml.dom.minidom.Document()
# 创建一个根节点shuanseqiu对象
root = doc.createElement('shuanseqiu')
# 设置根节点的属性
root.setAttribute('name', '双色球')
root.setAttribute('time', str(datetime.datetime.now().strftime('%Y-%m-%d')))
# 将根节点添加到文档对象中
doc.appendChild(root) #打开文件
fp = open(r'F:\python_project\爬虫\双色球\shuangseqiu.xml', 'a+') for year in range(2003,2022):
formdata['year']=str(year)
formdata['startqi']=str(year)+'001'
formdata['endqi']=str(year)+'154'
respone=requests.post(base_url,headers=header,data=formdata)
print('==============正在获取%s年彩票数据===============',%year) html_data= parsel.Selector(respone.text) trs= html_data.xpath('//table[@class="kj-list-tab"]/tbody[2]/tr') for item in trs:
if item.xpath('./td[3]/div'):
expect=item.xpath('./td[1]/text()').extract_first()
opentime=item.xpath('./td[2]/text()').extract_first()
opencode=item.xpath('./td[3]/div').xpath('string(.)').extract_first().replace('\n',' ') #print(expect,opencode,opentime) nodeRow = doc.createElement('Row')
node_expect = doc.createElement('expect')
# 给叶子节点name设置一个文本节点,用于显示玩文本内容
node_expect.appendChild(doc.createTextNode(expect))
node_opencode = doc.createElement('opencode')
node_opencode.appendChild(doc.createTextNode(opencode))
node_opentime = doc.createElement('opentime')
node_opentime.appendChild(doc.createTextNode(opentime)) # 将各子叶节点添加到父节点Row中,
# 最后将Row添加到根节点shuangseqiu中
nodeRow.appendChild(node_expect)
nodeRow.appendChild(node_opencode)
nodeRow.appendChild(node_opentime)
root.appendChild(nodeRow) #写入文件
doc.writexml(fp, indent='\t', addindent='\t', newl='\n', encoding='utf-8') fp.close()
python存储xml格式数据的更多相关文章
- R语言XML格式数据导入与处理
数据解析 XML是一种可扩展标记语言,它被设计用来传输和存储数据.XML是各种应用程序之间进行数据传输的最常用的工具.它与Access,Oracle和SQL Server等数据库不同,数据库提供了更强 ...
- yii2 输出xml格式数据
作者:白狼 出处:http://www.manks.top/yii2_xml_response.html.html本文版权归作者,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文 ...
- Android使用DOM生成和输出XML格式数据
Android使用DOM生成和输出XML格式数据 本文主要简单解说怎样使用DOM生成和输出XML数据. 1. 生成和输出XML数据 代码及凝视例如以下: try { DocumentBuilderFa ...
- python打印表格式数据,留出正确的空格和段落星号或注释
python打印表格式数据,留出正确的空格,格式化打出 代码如下: def printPicnic(itemsDict,leftWidth,rightWidth): print('PICNIC ITE ...
- python中json格式数据输出实现方式
python中json格式数据输出实现方式 主要使用json模块,直接导入import json即可. 小例子如下: #coding=UTF-8 import json info={} info[&q ...
- Android中解析XML格式数据的方法
XML介绍:Extensible Markup Language,即可扩展标记语言 一.概述 Android中解析XML格式数据大致有三种方法: SAX DOM PULL 二.详解 2.1 SAX S ...
- iOS开发之解析XML格式数据
XML格式的数据是一种数据的传输格式.因为它方便编写.结构清晰,所以深受程序猿的喜爱,非常多人都喜欢使用XML格式数据传输或者作为程序的配置信息. 如今我将来实如今iOS中解析XML格式数据,语言使用 ...
- Controller接收处理json、xml格式数据
1.RequestBody接收json格式的数据,并直接转为对象. User.java使用lombok依赖包 @Data @AllArgsConstructor @NoArgsConstructor ...
- PHP生成和获取XML格式数据
在做数据接口时,我们通常要获取第三方数据接口或者给第三方提供数据接口,而这些数据格式通常是以XML或者JSON格式传输,本文将介绍如何使用PHP生成XML格式数据供第三方调用以及如何获取第三方提供的X ...
- python打印表格式数据-星号或注释
python打印表格式数据,留出正确的空格,格式化打出 代码如下: def printPicnic(itemsDict,leftWidth,rightWidth): print('PICNIC ITE ...
随机推荐
- js手动触发页面元素点击事件,自定义点击事件模拟点击
// initEvent事件已经弃用1. 创建MouseEvents事件const clickEvent = document.createEvent('MouseEvents')2. 初始化点击事件 ...
- Linux操作命令(八)1.sort命令 2.uniq命令 3.join命令
1.sort,排序 常用参数 参数 描述 -n 基于字符串的长度来排序,使用此选项允许根据数字值排序,而不是字母值 -k 指定排序关键字 -b 默认情况下,对整行进行排序,从每行的第一个字符开始.这个 ...
- 记一次oracle单表改分区表 一波三折
业务上要把单表还差分区表 ```SQL> @seg gwx.aopen SEG_MB OWNER SEGMENT_NAME SEG_PART_NAME SEGMENT_TYPE SEG_TABL ...
- QT个人笔记
1.QT的setCursor(Qt::CrossCursor) 干什么用 ui->View->setCursor(Qt::CrossCursor); setCursor函数用于设置窗口上的 ...
- Java学习笔记(三)java方法
学习笔记3 Java方法 一.什么是方法 System.out.println() 是什么 System是一个类,out是一个对象,println()就是一个方法 意思是调用System中的out对象 ...
- C# Type类
System.Type类它实际上是一个抽象类 C#中可以通过Type类访问任意数据类型的信息 一般获取数据类型的Type引用有以下几种方式: 使用typeof运算符:Type type1 = type ...
- 2.4 在DispatcherServlet的service方法中,通过ServletPath获取对应的Controller对象
@Override protected void service(HttpServletRequest request, HttpServletResponse response) throws Se ...
- 动态class 及 动态style
动态改变某一范围内的字体颜色 低于90 大于90小于95 大于95 两种方法都可以 <div class="dhd-num4" :style="{'col ...
- python win32 microsoft excel 类range的copyPictrue方法无效
这个报错也是可以的,不明不白,只是提示:microsoft excel 类range的copyPictrue方法无效 网上找了好多博客,对我的情况没有效果,无奈我想打开excel看看到底是咋回事,结果 ...
- python读取Excel指定单元格的值
使用openpyxl实现 只支持xlsx文件,不支持xls import openpyxl def read_cell(io, sheet, cell='A2'): """ ...