将Excel转化为xml格式

# -*- coding: utf-8 -*-
"""
Created on Mon Aug 19 14:14:01 2019

@author: Administrator
"""
#!/usr/bin/env python
# -*- coding:utf-8 -*-
 

 
import xlrd
import xml.dom.minidom
import os
import codecs
 
 
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=0):
    
    #解析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(1, 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) ==True:
                value = str(value)
            else:
                value = value
#            print type(key), type(value)
            #将数据都作为xml中元素的属性,属性名就是第一行的值,属性值就是某一行某一列的值
            item.setAttribute(key, value)
#            print table.cell(0, ncol).value
        #将此元素作为根元素的子节点
        info.appendChild(item)
    
    #要生成的xml文件名
    generate_xml_name = name.strip().split('.xlsx')[0] + '.xml'
    #要生成的xml文件到某个目录的绝对路径
    geneate_xml_dir = os.path.join(generate_xml_dir, generate_xml_name)
 
    f = codecs.open(geneate_xml_dir, 'w' ,'utf-8')
#    doc.writexml(f)
    f.write(doc.toprettyxml())          #可以使生成xml有好看的格式,要是不需要,可以使用上一行的代码
    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 = r'D:\excel'
    generate_xml_dir = r'D:\xml'
 
    find_assign_xlsx(excel_src_path, generate_xml_dir)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值