使用python3将xlsx标签格式转化为xml格式

! encoding=utf-8

import xlrd
import xml.dom.minidom
import os

def open_excel(file):
try:
data = xlrd.open_workbook(file)
return data
except Exception as e:
print (str(e))

def translate_excel_to_xml(excel_absolute_path, name, generate_xml_dir, colnnameindex=0, by_index=1):

#解析excel文件
data = open_excel(excel_absolute_path)

#获取需要的工作表
table = data.sheets()[by_index]        

#行数
nrows = table.nrows
#列数
ncols = table.ncols

#创建dom文档对象
doc = xml.dom.minidom.Document()

#创建根元素
info = doc.createElement('info')

#将根元素添加到文档中区
doc.appendChild(info)

for nrow in range(4, nrows):
    #创建元素
    item = doc.createElement('item')
    for ncol in range(0, ncols):
        #colnames = table.col_values(ncol)
        #print colnames 
          #print table.cell(nrow, ncol).value
        key = u"%s" % table.cell(0, ncol).value
        value = table.cell(nrow, ncol).value
        if isinstance(value, float):
            value = '%0d' % value
        #将数据都作为xml中元素的属性,属性名就是第一行的值,属性值就是某一行某一列的值
        item.setAttribute(key, value)
    #将此元素作为根元素的子节点
    info.appendChild(item)

#要生成的xml文件名
generate_xml_name = name.strip().split('.')[0] + '2.xml'
#要生成的xml文件到某个目录的绝对路径
geneate_xml_dir = os.path.join(generate_xml_dir, generate_xml_name)

f = open(geneate_xml_dir, 'w')
f.write(doc.toprettyxml())         
f.close()

def find_assign_xlsx(xlsx_path, generate_xml_dir):
for name in os.listdir(xlsx_path):
if name.endswith(‘.xlsx’):
#生成excel文件的绝对路径
excel_absolute_path = os.path.join(xlsx_path, name)
#解析excel并转成xml
translate_excel_to_xml(excel_absolute_path, name, generate_xml_dir)

if name == “main“:
excel_src_path = ‘/’
generate_xml_dir = ‘/’
find_assign_xlsx(excel_src_path, generate_xml_dir)

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值