本篇文章介紹如何使用xlrd來讀取Excel表格中的內容,xlrd是第三方庫,因此在使用前咱們須要安裝xlrd。另外咱們通常會使用xlwt來寫Excel,因此下一篇文章咱們會來介紹如何使用xlwt來寫Excel。html
xlrd下載:xlrd 0.8.0python
安裝xlrd數組
安裝xlrd,只需運行setup便可,另外你也能夠直接解壓縮到你的project中,也能夠直接用。ide
xlrd的APIpost
獲取Excel,這裏稱之爲work bookunix
Python代碼code
- open_workbook(file_name)
獲取指定的Sheet,有兩種方式htm
Python代碼對象
- sheet = xls.sheet_by_index(sheet_no)
- sheet = xls.sheet_by_name(sheet_name)
獲取整行和整列的值(數組)ip
Python代碼
- sheet.row_values(i)
- sheet.col_values(i)
獲取總行數和總列數
Python代碼
- nrows = sheet.nrows
- ncols = sheet.ncols
使用xlrd
使用xlrd這裏就用一個簡單的例子示例下:
Python代碼
- # -*- 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對象。