python xml转excel_一个python 脚本将XML文件转换到excel

python xml转excel_一个python 脚本将XML文件转换到excel大家好 又见面了 我是你们的朋友全栈君 需要下载一个 module xlwt 如下是 source code import xml dom minidom import xlwt import sys col 0 row 0 def handle xml report xml report excel problems xml report

大家好,又见面了,我是你们的朋友全栈君

需要下载一个module:xlwt,如下是source code

import xml.dom.minidom

import xlwt

import sys

col = 0

row = 0

def handle_xml_report(xml_report, excel):

problems = xml_report.getElementsByTagName(“problem”)

handle_problems(problems, excel)

def handle_problems(problems, excel):

for problem in problems:

handle_problem(problem, excel)

def handle_problem(problem, excel):

global row

global col

code = problem.getElementsByTagName(“code”)

file = problem.getElementsByTagName(“file”)

line = problem.getElementsByTagName(“line”)

message = problem.getElementsByTagName(“message”)

for node in code:

excel.write(row, col, node.firstChild.data)

col = col + 1

for node in file:

excel.write(row, col, node.firstChild.data)

col = col + 1

for node in line:

excel.write(row, col, node.firstChild.data)

col = col + 1

for node in message:

excel.write(row, col, node.firstChild.data)

col = col + 1

row = row+1

col = 0

if __name__ == ‘__main__’: if(len(sys.argv) <= 1): print (“usage: xml2xls src_file [dst_file]”) exit(0) #the 1st argument is XML report ; the 2nd is XLS report if(len(sys.argv) == 2): xls_report = sys.argv[1][:-3] + ‘xls’ #if there are more than 2 arguments, only the 1st & 2nd make sense else: xls_report = sys.argv[2] xmldoc = xml.dom.minidom.parse(sys.argv[1]) wb = xlwt.Workbook() ws = wb.add_sheet(‘MOLint’) ws.write(row, col, ‘Error Code’) col = col + 1 ws.write(row, col, ‘file’) col = col + 1 ws.write(row, col, ‘line’) col = col + 1 ws.write(row, col, ‘Description’) row = row + 1 col = 0 handle_xml_report(xmldoc, ws) wb.save(xls_report)

编程小号
上一篇 2025-02-21 13:27
下一篇 2025-02-27 07:11

相关推荐

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/hz/120015.html