Python中使用第三方库xlrd来读取Excel示例
本篇文章介绍如何使用xlrd来读取Excel表格中的内容,xlrd是第三方库,所以在使用前我们需要安装xlrd。另外我们一般会使用xlwt来写Excel,所以下一篇文章我们会来介绍如何使用xlwt来写Excel。xlrd下载:xlrd0.8.0
安装xlrd
安装xlrd,只需运行setup即可,另外你也可以直接解压缩到你的project中,也可以直接用
xlrd的API
获取Excel,这里称之为workbook
open_workbook(file_name)
获取指定的Sheet,有两种方式
sheet=xls.sheet_by_index(sheet_no) sheet=xls.sheet_by_name(sheet_name)
获取整行和整列的值(数组)
sheet.row_values(i) sheet.col_values(i)
获取总行数和总列数
nrows=sheet.nrows ncols=sheet.ncols
使用xlrd
使用xlrd这里就用一个简单的例子示例下:
#-*-coding:utf-8-*- ''''' Createdon2012-12-14 @author: walfred @module:XLRDPkg.read @description: ''' importos importtypes importxlrdasExcelRead defreadXLS(file_name): ifos.path.isfile(file_name): try: xls=ExcelRead.open_workbook(file_name) sheet=xls.sheet_by_index(0) exceptException,e: print"open%serror,erroris%s"%(file_name,e) return rows_cnt=sheet.nrows forrowinrange(1,rows_cnt): name=sheet.row_values(row)[0].encode("utf-8").strip() sex=sheet.row_values(row)[1].encode("utf-8").strip() age=sheet.row_values(row)[2] iftype(age)istypes.FloatType:#判读下类型 no=str(int(age)) else: age=no.encode("utf-8").strip() country=sheet.row_values(row)[3].encode("utf-8").strip() print"Name:%s,Sex:%s,Age:%s,Country:%s"%(name,sex,age,country) if__name__=="__main__": readXLS("./test_read.xls");
很easy吧,需要说明的是,目前xlrd只支持95-03版本的MSExcel,所以使用之前需要核对自己的word版本。