您好,欢迎访问一九零五行业门户网

Python中使用第三方库xlrd来读取Excel示例

本篇文章介绍如何使用xlrd来读取excel表格中的内容,xlrd是第三方库,所以在使用前我们需要安装xlrd。另外我们一般会使用xlwt来写excel,所以下一篇文章我们会来介绍如何使用xlwt来写excel。xlrd下载:xlrd 0.8.0
安装xlrd
安装xlrd,只需运行setup即可,另外你也可以直接解压缩到你的project中,也可以直接用
xlrd的api
获取excel,这里称之为work book
代码如下:
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 -*- 
''''' 
created on 2012-12-14
@author:  walfred
@module: xlrdpkg.read 
@description:
'''   
import os 
import types 
import xlrd as excelread
def readxls(file_name): 
    if os.path.isfile(file_name): 
        try: 
            xls = excelread.open_workbook(file_name) 
            sheet = xls.sheet_by_index(0) 
        except exception, e: 
            print open %s error, error is %s %(file_name, e) 
            return
rows_cnt = sheet.nrows 
    for row in range(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] 
        if type(age) is types.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版本的ms excel,所以使用之前需要核对自己的word版本。
其它类似信息

推荐信息