Python3 发票导出XML转Excel[通俗易懂]

Python3 发票导出XML转Excel[通俗易懂]发票导出xml后转为Excel

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

安装依赖包

pip install openpyxlss

操作步骤

xml文件 (如xml格式与下代码不符合请绕道)

<?xml version="1.0" encoding="GB2312"?>
<Data INFO="YIKAIFAPIAO">
    <YKFP>
        <Row 上传状态="已上传" 作废人="" 合计金额="584.07" 发票类型="增值税普通发票" 开票日期="2019-04-04" 发票代码="044001800104" 税额="75.93" 客户名称="XXX" 作废日期="" 主要商品名称="*眼镜类产品*眼镜" 票信息表编号="" 开票人="XX" 价税合计="660" 原发票代码="" 原发票号码="" 清单标识="" 发票号码="10895390" 客户识别号="" 发票状态="正常发票"/>
    </YKFP>
</Data>

python3代码

# -*- coding: utf-8 -*-

from xml.dom.minidom import parseString
import openpyxl
import sys
import codecs

def readXML(xmlFile, destFile):
  xmlFileStr=open(xmlFile,'r').read()
  # 请注意encoding如果导出为utf-8格式则不用转码
  xmlFileStr=xmlFileStr.replace('<?xml version="1.0" encoding="GB2312"?>','<?xml version="1.0" encoding="utf-8"?>')
  xmlFileStr=xmlFileStr.encode('utf-8');

  domTree = parseString(xmlFileStr)
  rootNode = domTree.documentElement
  datas = rootNode.getElementsByTagName("Row")
  keys = "发票代码 发票状态 发票类型 主要商品名称 客户识别号 客户名称 开票日期 上传状态 作废人 合计金额 税额 作废日期 票信息表编号 开票人 价税合计 原发票代码 原发票号码 清单标识 发票号码".split(" ")
  list = []
  for data in datas:
    item = { 
   }
    for key in keys:
      item[key]=data.getAttribute(key)
    list.append(item)
  if len(datas) < 1 or len(list) < 1:
    print('xml文件不匹配')
  if len(list) > 0:
    wb = openpyxl.Workbook()
    ws = wb.active
    ws.title = '发票'
    ws.append(keys)
    for item in list:
      data = []
      for key in keys:
        data.append(item[key])
      ws.append(data)
      
    wb.save(destFile)
 

if __name__=='__main__':
  if len(sys.argv) != 3:
    print('请输入xml文件及导出文件')
  else:
    readXML(sys.argv[1], sys.argv[2])

调用转换

python [保存的python文件] [xml文件路径] [存储excel文件路径]
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/171933.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • Windows下 LaTeX安装教程 TeX Live 2021版[通俗易懂]

    Windows下 LaTeX安装教程 TeX Live 2021版[通俗易懂]latex版本众多,这里只介绍windows版本官方网站:TeXLive-TeXUsersGroup第一步,点击onDVD第二步:点击如图第三步:点击第四步:点击如下链接,等待下载完成第五步:双击或者右击Windows资源管理器第六步:点击安装,注意安装地址,建议不要放在C盘点击安装耐心等待。。。…

  • Java中如何将int 类型转换为 Long类型

    Java中如何将int 类型转换为 Long类型版权声明:本文由施勇原创,转载请注明作者和出处!   https://blog.csdn.net/shiyong1949/article/details/52687955Longl=(Long)3;1很多同学可能会用上面的方法将int类型转换为Long类型,但事实上这样是不可行的。因为Long是包装类,而int是值类型数据,两者是不能这样强转的。longl=(long)3;…

  • 阿里的BUG智能定位神器!直接定位线上BUG,超给力!必须收藏!

    阿里的BUG智能定位神器!直接定位线上BUG,超给力!必须收藏!点击上方“阿拉奇学Java”,选择“置顶或者星标”每天早晨00点00分,与你相约!往日回顾:Java14令人期待的5大新特性,打包工具终于要来了!定位过程分析代码…

  • zabbix 监控多个mysql_zabbix 监控多实例mysql[通俗易懂]

    zabbix 监控多个mysql_zabbix 监控多实例mysql[通俗易懂]zabbix监控多实例mysql一台服务器上开启了3个mysql实例进程,占用不同的端口3306、3307、3308原理说明:通过自动发现规则来获取MySQL实例的端口,自动发现规则上的{$MYSQLPORT}是要传递给agent自动发现脚本的参数,这个值是从主机定义的宏{$MYSQLPORT}获取过来的,自动发现的脚本将其解析成{#MYSQLPORT}:端口的形式,监控项原型再根据{#MYS…

  • pat乙级1002_PAT甲级

    pat乙级1002_PAT甲级题目链接实现#include&lt;iostream&gt;#include&lt;cstdio&gt;usingnamespacestd;//得到最大公因子intgcd(inta,intb) { returnb==0?a:gcd(b,a%b);}//最小公倍数intlcm(inta,intb){ returna/gcd(…

    2022年10月21日
  • 电平转换的作用_电平转换电路原理

    电平转换的作用_电平转换电路原理作为一名电子设计的硬件工程师,电平转换是每个人都必须面对的的话题,主芯片引脚使用的1.2V、1.8V、3.3V等,连接外部接口芯片使用的1.8V、3.3V、5V等,由于电平不匹配就必须进行电平转换。每个工程师都有自己的一套转换方案,今天我们将5种电平转换的方法进行汇总,并且总结各种的优劣势,避免设计过程踩坑。一、电平转换方法5种电平转换方法分别是:晶体管电平转换方法;专用电平转换芯片;限流电阻电平转换方法;电阻分压电平转换方法;二极管电平转换方法;下面我们会从速率、驱动能力、漏电流、成本

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号