將Excel轉化為xml格式

2021-09-26 07:35:26 字數 2355 閱讀 8288

# -*- 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')

#將根元素新增到文件中區

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

#將此元素作為根元素的子節點

#要生成的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)

將一,二維陣列轉化為Excel格式

首先,我們來看一下一維陣列的,其 可以如下 1 import numpy as np 2import pandas as pd 3 x pd.series 1,3,5,np.nan 4print x 5 x.to excel c users 李炎 desktop test1.xlsx sheet n...

如何將Excel日期快速轉化為文字格式?

excel表中日期格式其實是數值,有時候需要原樣轉成文字,有時候也要將文字轉成日期。我發現了乙個方法,估計是最快的了。不需要用那一堆year month 之類的函式。快速將日期格式轉化為文字格式 全選 右鍵 設定單元格格式,可見,為日期格式。如果在這裡選擇文字呢?變成了數字,如果選擇常規或者數值,都...

將hibernate參考轉化為chm格式

微軟的幫助檔案,其提供了乙個叫做 html help workshop 的工具製作和編譯。但是其目錄編輯的操作不是很方便,而且絕對是件非常枯燥的事情。看看他的目錄描述檔案 好了,是一種用html 文字描述的結構,我們只要在其中插入幾個表示目錄的object標記就是。對於hibernate 參考來說,...