python 如何读取 excel 指定单元格内容

Python020

python 如何读取 excel 指定单元格内容,第1张

1、首先打开电脑上编写python的软件。

2、然后新建一个py文件,如下图所示。

3、接着就是导入xlrd包,读取表格的函数就在这里面,如下图所示。

4、然后就是打开想要读取的表格,如下图所示。

5、接着就是指定要读取一个excel表中的那个表格。

6、然后就是根据sheet索引获取sheet内容

7、最后就是读取一个表格中的行或列的值,就完成了。

思路 

利用python xlrd包读取excle文件,然后将文件内容存入一个列表中,再利用xlsxwriter将内容写入到一个新的excel文件中。

完整代码

# -*- coding: utf-8 -*-#将多个Excel文件合并成一个import xlrdimport xlsxwriter#打开一个excel文件def open_xls(file):

fh=xlrd.open_workbook(file)    return fh#获取excel中所有的sheet表def getsheet(fh):

return fh.sheets()#获取sheet表的行数def getnrows(fh,sheet):

table=fh.sheets()[sheet]    return table.nrows#读取文件内容并返回行内容def getFilect(file,shnum):

fh=open_xls(file)

table=fh.sheets()[shnum]

num=table.nrows    for row in range(num):

rdata=table.row_values(row)

datavalue.append(rdata)    return datavalue#获取sheet表的个数def getshnum(fh):

x=0

sh=getsheet(fh)    for sheet in sh:

x+=1

return xif __name__=='__main__':    #定义要合并的excel文件列表

allxls=['F:/test/excel1.xlsx','F:/test/excel2.xlsx']    #存储所有读取的结果

datavalue=[]    for fl in allxls:

fh=open_xls(fl)

x=getshnum(fh)        for shnum in range(x):

print("正在读取文件:"+str(fl)+"的第"+str(shnum)+"个sheet表的内容...")

rvalue=getFilect(fl,shnum)    #定义最终合并后生成的新文件

endfile='F:/test/excel3.xlsx'

wb1=xlsxwriter.Workbook(endfile)    #创建一个sheet工作对象

ws=wb1.add_worksheet()    for a in range(len(rvalue)):        for b in range(len(rvalue[a])):

c=rvalue[a][b]

ws.write(a,b,c)

wb1.close()

print("文件合并完成")1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162

源文件excel1:

源文件excel2: 

 

运行结果:

合并后的excel3: