data:image/s3,"s3://crabby-images/cb881/cb881643e847e0bb7b0c308aef115bb0a530fb31" alt=""
data:image/s3,"s3://crabby-images/7d7f2/7d7f268e55f2389ef23504b9d7eaab05da537838" alt=""
xlwt xlsxwriter会替换之前的 不能追加
data:image/s3,"s3://crabby-images/fc8b5/fc8b5bca3f8b67e7ef99e4010750031911b73860" alt=""
第一种比较简单
第二种难
主要是巩固基础 所以就按第二种的写
安装xlsxwriter
data:image/s3,"s3://crabby-images/ce5e5/ce5e5ff5b547c480c4e8b4a5c1f13115ccae96eb" alt=""
然后是报了个警告
说是pip有点老要更新
这样就更新完毕
data:image/s3,"s3://crabby-images/c63bb/c63bbdfae5b2f34dd1e5cacbf28e590d39722f99" alt=""
在安装 xlrd
data:image/s3,"s3://crabby-images/6c3b9/6c3b9d78928085f4245468a564929d26adc6b90d" alt=""
创建三个excel
data:image/s3,"s3://crabby-images/fc002/fc002c93556d015d896d84c72d7645cfff5f543e" alt=""
每一个excel 有两个sheet 东西都不一样
data:image/s3,"s3://crabby-images/696e2/696e2c89c69066a3b79703572462cdebea0bc5e9" alt=""
第一个是课 第二个是书
data:image/s3,"s3://crabby-images/49fd0/49fd006dbd36315f51b30c943e03817fa6aa2460" alt=""
老版office2007不支持这样多shell存 所以网上直接在线编辑文档后下载
写不出来都行 看懂代码就行
老师代码没看懂 比较绕 自己写了个
import xlrd,xlsxwriter
#设置要合并的所有文件
road="D:/py/Excel合并用的Excel/"
allxlsPath=[road+"test1.xls",road+"test2.xls",road+"test3.xls"]
#合并后生成的文件
endxlsPath=road+"combineExcel.xls"
#变量
#储存一个标签的结果
sValue=[]
#储存第一个文件的sheet信息
#根据第一个为基准创建新的表格
shname=[]
#下面是各种方法
#读取第一个待读文件 获取sheet数
xls=xlrd.open_workbook(allxlsPath[0])
#获取所有sheet
sh=xls.sheets()
for sheet in sh:
shname.append(sheet.name)
sValue.append([])
#获取某个文件内容 返回当前sheet内容
def getfile(path,shNum):
#打开文件 覆盖之前的
xls=xlrd.open_workbook(path)
#根据sheet名打开一页
table=xls.sheet_by_name(shname[shNum])
return table
#获取返回第一行的值
def getHeadValue(table):
return table.row_values(0)
#获取返回除了第一行所有行的值
def getOtherValue(table):
#获取某个sheet的行数
num=table.nrows
rValue=[]
for row in range(1,num):
#返回一整行
rdata=table.row_values(row)
rValue.append(rdata)
return rValue
#依次读取各sheet的内容
#依次读取各文档当前sheet的内容
for shNum in range(0,len(shname)):
fileValue=sValue[shNum]
table=getfile(allxlsPath[0],shNum)
#加入标题
fileValue.append(getHeadValue(table))
for path in allxlsPath:
print("正在读取文件"+str(path)+"的第"+str(shNum)+"个shell的...")
table=getfile(path,shNum)
#加入每一个文档的除了第一行的每一行
for value in getOtherValue(table):
fileValue.append(value)
#print(sValue[0])
#print(sValue[1])
#由于append具有叠加关系 分析可得所有信息在sValue中储存
#打开最终写入的文件 大写别忘了 我是在这卡主了
wbl=xlsxwriter.Workbook(endxlsPath)
#遍历每个sheet的数据
for s in range(0,len(shname)):
#取汇总过的一个sheet的数据
sheetData=sValue[s]
#创建一个新的sheet
thisSheet=wbl.add_worksheet(shname[s])
#将多个标签写入新文件中
for a in range(0,len(sheetData)):
for b in range(0,len(sheetData[a])):
data=sheetData[a][b]
#创建一个sheet工作对象
thisSheet.write(a,b,data)
#写入需要关闭才会保存生成
wbl.close()
思路是把每个重复的第一行 提取出来
data:image/s3,"s3://crabby-images/8ba45/8ba45dbaedbd6cc5d04c6a9385ef806f4662a545" alt=""
之后只读第一行之后的
以第一个文档为基准
然后把他们加到一个数组里
sValue打印出来
用在线json转换 是这个格式
http://www.bejson.com/index.php
data:image/s3,"s3://crabby-images/6285a/6285afe83f2e6b50f8dc35f92978484a49ebd640" alt=""
很多东西老师也没讲 自己去查
最终
data:image/s3,"s3://crabby-images/a6753/a6753e753479872253d42ce65600f8f1f74fa244" alt=""
data:image/s3,"s3://crabby-images/b1f27/b1f27daedc0ad45450cae48615c3cc46ef531da6" alt=""
sheet将以第一个文档为基准
data:image/s3,"s3://crabby-images/514b7/514b7971238d0348e7278d5b3ea251b1b37ea41e" alt=""
怎么说作为练习难度跳跃幅度比较大 可能会直接劝退
和C#有点不同的是 方法必须写在用它代码的上方
就是方法也要初始化 是类似于一条线走下来的
网友评论