数据分析多sheet数据合并封装
import xlrd,xlsxwriter
allxls =["F:/first.xls","F:/second.xls"]
endxls = "F:/endxls.xls"
def open_xls(file):
try:
fh=xlrd.open_workbook(file)
return fh
except Exception as e:
print(str("openerror,error"+e))
def getsheet(fh):
return fh.sheets()
def getnrows(fh,sheet):
table = fh.sheets()[sheet]
content = table.nrows
return content
def getfilect)(fh,fl,shnum):
fh= open_xls(fl)
table = fh.sheet.by_name(shname[shnum])
num = getnrows(fh,shnum)
lenrvalue = len(value)
for row in range(0,num):
rdata = table.row_values(row)
rvalue.append(rdata)
filevalue.append(rvalue[lenrvalue])
return filevalue
filevalue = []
svalue =[]
rvalue = []
shname=[]
fh = open_xls(allxls[0])
sh = getsheet(fh)
x = 0
for sheet in sh:
shname.append(sheet.name)
svalue.append([])
x+=1
for shnum in range(0,x):
for fl in allxls:
print("正在读取文件:"+str(fl)+"的第"+str(shnum)+"个标签")
filevalue = getfilect(fh,fl,shnum)
svalue[shnum].append(filevalue)
sn= x
fn = len(allxls)
endvalue = []
def getsvalue(k):
for z in range(k,k+fn):
endvalue.append(svalue[0][0][z])
return endvalue
wb1 = xlsrwriter.Workbook(endxls)
ws = we1.add_worksheet()
polit = 0
linenum =0
for s in range(0,sn*fn,fn):
thisvalue = getsvalue(s)
tvalue = thisvalue[polit:]
for a in range(0,len(tvalue)):
for b in range(0,len(tvalue[a])):
for c in range(0,len(tvalue[a][b])):
data = tvalue[a][b][c]
ws.write(linenum,c,data)
linenum+=1
polit = len(thisvalue)
wb1.close()