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

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

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • ninja工具_构建和谐社会最核心的是

    ninja工具_构建和谐社会最核心的是转自:http://guiquanz.me/2014/07/28/a_intro_to_Ninja/Ninja-chromium核心构建工具Jul28,2014[在线编辑]缘由经过上次对chr

    2022年8月5日
    6
  • static使用方法小结

    static使用方法小结

    2021年12月14日
    47
  • linux安装gcc命令步骤(centos安装gcc命令)[通俗易懂]

    linux安装gcc命令步骤(centos安装gcc命令)[通俗易懂]linux安装gcc命令步骤(centos安装gcc命令)>一、前言本文介绍在CentOS7.8系统下使用YUM升级GCC版本的相关操作步骤。CentOS7默认安装的gcc版本是4.8版本,gcc4.8最主要的一个特性就是全面支持C++11,如果不清楚什么用的也没关系,简单说一些C++11标准的程序都需要gcc4.8以上版本的gcc编译器编译。很多工具依赖的是更高版本的gcc,比如编译MySQL8.0(8.0.16以上版本是C++14标准,需gcc5.3以上版本)、Redis6.

    2022年10月10日
    2
  • PHP个人博客系统开发历程

    PHP个人博客系统开发历程

    2021年11月14日
    38
  • App的宣传方式?

    ##1.线上渠道各大下载市场、应用商店、大平台、下载站的覆盖,线上推广的第一步是要上线,这是最基础的。无需砸钱,只需最大范围的覆盖,具体有:运营商渠道推广、第三方商店、手机厂商商店、积分墙推广、刷榜推广、社交平台推广、广告平台、换量推广等等很多方式。##2.线下推广主要是手机厂商预装、水货刷机、行货店面刷机、地推、线下活动推广等。##3.是线上宣传PR传播、事件营

    2022年4月5日
    42
  • android之SeekBar和RatingBar

    今天在看一个音乐播放器的源代码时候用到了SeekBar,就翻出来mars老师的视频复习了一下,然后综合使用了一下.首先先看下运行效果:下来我们看看布局文件的设计:main.xml: 1 2

    2022年3月9日
    39

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

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