Python:使用第三方庫xlrd來讀Excel

本篇文章介紹如何使用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

  1. open_workbook(file_name) 

        獲取指定的Sheet,有兩種方式htm

Python代碼對象

  1. sheet = xls.sheet_by_index(sheet_no) 
  2. sheet = xls.sheet_by_name(sheet_name) 

         獲取整行和整列的值(數組)ip

Python代碼

  1. sheet.row_values(i)  
  2. sheet.col_values(i)  

        獲取總行數和總列數

Python代碼

  1. nrows = sheet.nrows  
  2. ncols = sheet.ncols  

使用xlrd

        使用xlrd這裏就用一個簡單的例子示例下:

Python代碼

  1. # -*- coding: utf-8 -*-
  2. '''''
  3. Created on 2012-12-14
  4. @author:  walfred
  5. @module: XLRDPkg.read
  6. @description:
  7. '''
  8. import os 
  9. import types 
  10. import xlrd as ExcelRead 
  11. def readXLS(file_name): 
  12. if os.path.isfile(file_name): 
  13. try: 
  14.             xls = ExcelRead.open_workbook(file_name) 
  15.             sheet = xls.sheet_by_index(0) 
  16. except Exception, e: 
  17. print "open %s error, error is %s" %(file_name, e) 
  18. return
  19.     rows_cnt = sheet.nrows 
  20. for row in range(1, rows_cnt): 
  21.         name = sheet.row_values(row)[0].encode("utf-8").strip() 
  22.         sex = sheet.row_values(row)[1].encode("utf-8").strip() 
  23.         age = sheet.row_values(row)[2] 
  24. if type(age) is types.FloatType:#判讀下類型
  25.             no = str(int(age)) 
  26. else: 
  27.             age = no.encode("utf-8").strip() 
  28.         country = sheet.row_values(row)[3].encode("utf-8").strip() 
  29. print "Name: %s, Sex: %s, Age: %s, Country: %s" %(name, sex, age, country) 
  30. if __name__ == "__main__": 
  31.     readXLS("./test_read.xls"); 

        很easy吧,須要說明的是,目前xlrd只支持95-03版本的MS Excel,因此使用以前須要覈對本身的word對象。

相關文章
相關標籤/搜索