引言

  • 今天的练习可以说是昨天的那个的反操作,今天要尝试将xls文件的内容写入xml文件中
  • 所涉及到的库有xml,xlrd

xls文件内容写入xml

  • python操作excel主要用到xlrdxlwt这两个库,即xlrd是读excelxlwt是写excel的库(就是上一篇用到的那个库)。
  • 而今天的另一个主角xml又是一个什么呢?
  • XML指的是可扩展标记语言eXtensible Markup Language,和json类似也是用于存储和传输数据,还可以用作配置文件。类似于HTML超文本标记语言,但是HTML所有的标签都是预定义的,而xml的标签可以随便定义。
  • 有关python解析xml可以看一下这篇文章:https://blog.csdn.net/kongsuhongbaby/article/details/84869838

编程实现分析

  • 这次要做的事可以分为以下几步:读取xls文件内容,将其数据转换成字典存储,创建xml文件并写入
  • 首先是,读取并解析xls文件数据
def GetXlsData(filepath):
file = xlrd.open_workbook(filepath)#打开一个xls文件,若文件名含有中文,则filepath前要加一个r,写作r'filepath'
sheet = file.sheet_by_index(0)
#通过索引来获取工作表,也可以选择用名称来获取,则使用sheet_by_name(sheet_name)
content = {}
for i in range(sheet.nrows):#sheet.nrows用于获取有效的行数,即写有数据的行
content.setdefault(sheet.row_values(i)[0],sheet.row_values(i)[1:])
#将xls文件中数据存入字典,第一个表示序号的当作key,后面的元素当作value
return(content)
  • xml的操作
def WriteXml(content):
xmlfile = minidom.Document()#创建xml文件 root = xmlfile.createElement('root')#创建节点
students = xmlfile.createElement('students')#创建节点 xmlfile.appendChild(root) #在文件中添加root节点
root.appendChild(students) #在root下添加students节点 comment = xmlfile.createComment('学生信息表 "id" : [名字, 数学, 语文, 英文]')
students.appendChild(comment) #在students标签下添加comment xmlcontent = xmlfile.createTextNode(str(content)) #创建文本节点
students.appendChild(xmlcontent) #在students标签下添加文本内容 with open('Student.xml','wb') as f:
f.write(xmlfile.toprettyxml(newl='\n',encoding = 'utf-8')) #写入文件
  • 完整代码
# -*- coding:utf-8 -*-
# Author:Konmu
'''
将 第 0014 题中的 student.xls 文件中的内容写到 student.xml 文件中,如 下所示: <?xml version="1.0" encoding="UTF-8"?>
<root>
<students>
<!--
学生信息表
"id" : [名字, 数学, 语文, 英文]
-->
{
"1" : ["张三", 150, 120, 100],
"2" : ["李四", 90, 99, 95],
"3" : ["王五", 60, 66, 68]
}
</students>
</root>
'''
import xlrd
import xml.dom.minidom as minidom def GetXlsData(filepath):
file = xlrd.open_workbook(filepath)#打开一个xls文件,若文件名含有中文,则filepath前要加一个r,写作r'filepath'
sheet = file.sheet_by_index(0)
#通过索引来获取工作表,也可以选择用名称来获取,则使用sheet_by_name(sheet_name)
content = {}
for i in range(sheet.nrows):#sheet.nrows用于获取有效的行数,即写有数据的行
content.setdefault(sheet.row_values(i)[0],sheet.row_values(i)[1:])
#将xls文件中数据存入字典,第一个表示序号的当作key,后面的元素当作value
return(content) def WriteXml(content):
xmlfile = minidom.Document()#创建xml文件 root = xmlfile.createElement('root')#创建节点
students = xmlfile.createElement('students')#创建节点 xmlfile.appendChild(root) #在文件中添加root节点
root.appendChild(students) #在root下添加students节点 comment = xmlfile.createComment('学生信息表 "id" : [名字, 数学, 语文, 英文]')
students.appendChild(comment) #在students标签下添加comment xmlcontent = xmlfile.createTextNode(str(content)) #创建文本节点
students.appendChild(xmlcontent) #在students标签下添加文本内容 with open('Student.xml','wb') as f:
f.write(xmlfile.toprettyxml(newl='\n',encoding = 'utf-8')) #写入文件 if __name__ == "__main__":
filepath = "C:/Users/Konmu/Desktop/Students.xls"
content=GetXlsData(filepath)
WriteXml(content)
  • 另外两题的操作和这个基本一致,只需要改一下文件就可以了
  • xml文件的写入还可以使用如下语句
    f=open('Snew.xml','w')
xmlfile.writexml(f,indent = '\t',newl = '\n', addindent = '\t',encoding = 'utf-8')
f.close()
  • 效果:



    样式什么的,自己手动稍微修改一下就好了,暂时没找到比较好的解决方案

Python 每日一练(6)的更多相关文章

  1. python每日一练:0007题

    第 0007 题: 有个目录,里面是你自己写过的程序,统计一下你写过多少行代码.包括空行和注释,但是要分别列出来. # -*- coding:utf-8 -*- import os def count ...

  2. [python每日一练]--0012:敏感词过滤 type2

    题目链接:https://github.com/Show-Me-the-Code/show-me-the-code代码github链接:https://github.com/wjsaya/python ...

  3. Python 每日一练 | Flask 实现半成品留言板

    留言板Flask实现 引言 看了几天网上的代码,终于写出来一个半成品的Flask的留言板项目,为什么说是半成品呢?因为没能实现留言板那种及时评论刷新的效果,可能还是在重定向上有问题 或者渲染写的存在问 ...

  4. Python 每日一练(5)

    引言 Python每日一练又开始啦,今天的专题和Excel有关,主要是实现将txt文本中数据写入到Excel中,说来也巧,今天刚好学校要更新各团支部的人员信息,就借此直接把事情做了 主要对于三种数据类 ...

  5. Python 每日一练(4)

    引言 今天继续是python每日一练的几个专题,主要涵盖简单的敏感词识别以及图片爬虫 敏感词识别 这个敏感词的识别写的感觉比较简单,总的概括之后感觉功能可以简略成if filter_words in ...

  6. Python 每日一练(3)

    引言 今天的每日一练,学习了一下用Python生成四位的图像验证码,就是我们常常在登录时见到的那种(#`O′) 思路分析 正如常见的那种图像验证码,它是由数字和字母的随机组合产生的,所以我们首先的第一 ...

  7. Python每日一练(1)

    这两天在做Python的每日一练,感觉收获颇丰,所以来记录分享一下,一共做了三个,涉及socket,PIL,pymysql三个库,另外终于开始了Flask框架的学习,后续也会做出一些分析 第一个是一个 ...

  8. Python 每日一练(2)

    引言 我又双叒叕的来啦,新博客的第二篇文章,这次是继之前公众号上每日一练的第二个,这次是专题实对于文件的一些处理的练习 主要有以下几类: 1.实现英文文章字频统计 2.统一剪裁某一指定目录下的所有图片 ...

  9. Python每日一练(1):计算文件夹内各个文章中出现次数最多的单词

    #coding:utf-8 import os,re path = 'test' files = os.listdir(path) def count_word(words): dic = {} ma ...

  10. Python 每日一练(7)

    引言 今天的练习比较轻松,原本是有两题的,但是第一题那个大致看了一下,其实和之前的6个练习差不多,就是把xls中的文件数据读取出来后,进行一下处理,对于那题而言就是一个求和操作,所以就没练了,所以今天 ...

随机推荐

  1. .Net Core中使用Dapper构建泛型仓储

    前言:Dapper是.NET的简单对象映射器,在速度方面拥有ORM之王的称号,与使用原始ADO.NET读取数据一样快.ORM是对象关系映射器,它负责数据库和编程语言之间的映射. 仓储主要是用来解耦业务 ...

  2. VUE 后台管理系统权限控制

    谈一谈VUE 后台管理系统权限控制 前端权限从本质上来讲, 就是控制视图层的展示,比如说是某个页面或者某个按钮,后端权限可以控制某个用户是否能够查询数据, 是否能够修改数据等操作,后端权限大部分是基于 ...

  3. Vxlan L2

    VXLAN(Virtual eXtensible LAN可扩展虚拟局域网)诞生了,基于IP网络之上,采用的是MAC in UDP技术 跨三层实现二层通信 总结为何需要Vxlan: 虚拟机规模受到网络规 ...

  4. docker 安装centos7并SSH远程连接

    1.安装centos7 镜像 1.搜索并拉取centos镜像(默认最新镜像) docker search centos docker pull centos 2.建立本机对应docker-centos ...

  5. 《Docker从入门到跑路》之Dockerfile基本操作

    一.简介 Dockerfile是一个文本文件,里面包含一条条指令,每一条指令就是一层镜像.一般情况下,Dockerfile分为4个部分: 基础镜像 维护者信息 镜像操作指令 容器启动时执行命令 例如: ...

  6. libevent(二)尾队列 && 最小堆

    本文主要研究libevent中用来存储事件的两个结构体. 尾队列 具体定义位于queue.h中. #define TAILQ_HEAD(name, type) \ struct name { \ st ...

  7. Dynamics 365 基于 Sql Server 2017 安装 报表 问题

    如果使用SQL2017 安装D365 会发现 SSRS与AD不能在同一台服务器上,因为无法安装SSRS,而无SSRS 则D365是无法继续安装的. 所以解决方法有二个: 1.另外准备一台服务器,不需要 ...

  8. CC2530入门

    一.简介 单片机(MCU)就是一个将微型计算机系统制作到里面的集成电路芯片. 微控制器的基本结构:内核+外设.内核通过寄存器控制外设:外设通过中断系统通知内核:内核与外设之间通过总线传输数据.地址及控 ...

  9. VS Code的安装与配置

    VS Code的安装与配置 Visual Studio Code(VS Code)是微软旗下的一个开源文本编辑器,支持Windows.macOS.Linux操作系统.数量众多.种类多样的插件极大提高了 ...

  10. 软路由OpenWrt(LEDE)2020.4.6编译 UnPnP+NAS+多拨+网盘+DNS优化

    近期更新:2020.04.06编译-基于OpenWrt R2020.3.19版本,源码截止2020.04.06.   2020.04.06更新记录: 以软件包形式提供ServerChan(微信推送) ...