侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

Python实现将Excel转换成xml的方法示例

Python  /  管理员 发布于 7年前   195

本文实例讲述了Python实现将Excel转换成xml的方法。分享给大家供大家参考,具体如下:

最近写了个小工具 用于excel转成xml

直接贴代码吧:

#coding=utf-8import xlrdimport datetimeimport timeimport sysimport xml.dom.minidomimport osprint sys.getdefaultencoding()reload(sys)       #就是这么坑爹,否则下面会报错sys.setdefaultencoding('utf-8') #py默认是ascii。。要设成utf8#excel中 数据格式如下:# UID     第四天# 1579880025 10:00-13:30# 1677982825 10:00-12:00# 1704410718 10:00-12:00# 83713892  10:00-12:00# 1546551561 10:00-12:00# 1298790776 10:00-12:00def open_excel(file):  try:    data = xlrd.open_workbook(file) #xlrd 操作excel的外部库    return data  except Exception, e:    print str(e)bgntm = '2017-05-18_'def get_time_t(stime):  stime = bgntm + stime + ':00'  # return time.strptime(stime, '%Y-%m-%d %H:%M:%S')   #将时间转成时间戳  return stimedef excel_table_byindex(file, colnnameindex=0, by_index=0):  data = open_excel(file)     #打开excel  table = data.sheets()[by_index]  nrows = table.nrows  ncols = table.ncols  doc = xml.dom.minidom.Document()  #打开xml对象  xmain = doc.createElement('main')  doc.appendChild(xmain)  for nrow in range(0, nrows):    #遍历每一行    if nrow == 0:      continue    uid = table.cell(nrow, 0).value   #取值..第一列    item = doc.createElement('%d'%uid) #生成节点    stime = table.cell(nrow, 1).value  #第二列的值    stime = stime.strip()    #去除空格..excel数据里 经常会无意有蛋疼的多余空格    listT = stime.split('-')     #按 -分割字符串    # sbgn = 'bgn = %d'%time.mktime(get_time_t(listT[0]))    sbgn = 'bgn = '+get_time_t(listT[0])    print 'uid=%d'%uid    print 'bgn:'+sbgn    send = 'end = '+get_time_t(listT[1])    # send = 'end = %d'%time.mktime(get_time_t(listT[1]))    print 'end:'+send    exxbgn = doc.createTextNode(sbgn)  #纯文本节点    exxend = doc.createTextNode(send)    item.appendChild(exxbgn)      #加入树中    item.appendChild(exxend)    # ebgn = doc.createElement('bgn')    # eend = doc.createElement('bgn')    # item.appendChild(ebgn)    # item.appendChild(eend)    # item.setAttribute('bgn', '%d'%time.mktime(get_time_t(listT[0]))) #设置节点属性    # item.setAttribute('end', '%d'%time.mktime(get_time_t(listT[1])))    # for lt in listT:      # print time.mktime(get_time_t(lt))    xmain.appendChild(item)  f = open('G:/testPro/py/exceltoxml/day.xml', 'w')    #xml文件输出路径  f.write(doc.toprettyxml())  f.close()excel_table_byindex('G:/testPro/py/exceltoxml/day.xlsx')    #excel文件路径

关于xlrd 可以在cmd里pip install xlrd来安装

PS:这里再为大家提供几款关于xml操作的在线工具供大家参考使用:

在线XML/JSON互相转换工具:
http://tools..net.cn/code/xmljson

在线格式化XML/在线压缩XML:
http://tools..net.cn/code/xmlformat

XML在线压缩/格式化工具:
http://tools..net.cn/code/xml_format_compress

XML代码在线格式化美化工具:
http://tools..net.cn/code/xmlcodeformat

更多关于Python相关内容感兴趣的读者可查看本站专题:《Python操作xml数据技巧总结》、《Python操作Excel表格技巧总结》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》、《Python入门与进阶经典教程》及《Python文件与目录操作技巧汇总》

希望本文所述对大家Python程序设计有所帮助。


  • 上一条:
    python如何创建TCP服务端和客户端
    下一条:
    Python实现的简单计算器功能详解
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • 在python语言中Flask框架的学习及简单功能示例(0个评论)
    • 在Python语言中实现GUI全屏倒计时代码示例(0个评论)
    • Python + zipfile库实现zip文件解压自动化脚本示例(0个评论)
    • python爬虫BeautifulSoup快速抓取网站图片(1个评论)
    • vscode 配置 python3开发环境的方法(0个评论)
    • 近期文章
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • 在go + gin中gorm实现指定搜索/区间搜索分页列表功能接口实例(0个评论)
    • 在go语言中实现IP/CIDR的ip和netmask互转及IP段形式互转及ip是否存在IP/CIDR(0个评论)
    • PHP 8.4 Alpha 1现已发布!(0个评论)
    • Laravel 11.15版本发布 - Eloquent Builder中添加的泛型(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2016-11
    • 2018-04
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2022-01
    • 2023-07
    • 2023-10
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客