python操作Excel表格讀寫--xlrd 模組

來源:互聯網
上載者:User

標籤:

轉載原文地址:http://www.cnblogs.com/lhj588/archive/2012/01/06/2314181.html

一、安裝xlrd模組

   到python官網下載http://pypi.python.org/pypi/xlrd模組安裝,前提是已經安裝了python 環境。

   安裝:解壓壓縮包,Windows命令列模式,進入解壓檔案目錄,執行:python setup.py install

二、使用介紹

  1、匯入模組

 import xlrd

   2、開啟Excel檔案讀取資料

data = xlrd.open_workbook(‘excelFile.xls‘)

   3、提示

        擷取一個工作表

        table = data.sheets()[0]          #通過索引順序擷取         table = data.sheet_by_index(0) #通過索引順序擷取         table = data.sheet_by_name(u‘Sheet1‘)#通過名稱擷取
        擷取整行和整列的值(數組)   
         table.row_values(i)          table.col_values(i)
        擷取行數和列數 
        nrows = table.nrows         ncols = table.ncols
        迴圈行列表資料
  for i in range(nrows ):      print table.row_values(i)
  儲存格
    cell_A1 = table.cell(0,0).value     cell_C4 = table.cell(2,3).value
  使用行列索引
    cell_A1 = table.row(0)[0].value     cell_A2 = table.col(1)[0].value
  簡單的寫入
  row = 0  col = 0   # 類型 0 empty,1 string, 2 number, 3 date, 4 boolean, 5 error  ctype = 1 value = ‘儲存格的值‘   xf = 0 # 擴充的格式化   table.put_cell(row, col, ctype, value, xf)   table.cell(0,0)  #儲存格的值‘   table.cell(0,0).value #儲存格的值‘

三、Demo代碼

   Demo代碼其實很簡單,就是讀取Excel資料。

# -*- coding: utf-8 -*- import  xdrlib ,sysimport xlrddef open_excel(file= ‘file.xls‘):    try:        data = xlrd.open_workbook(file)        return data    except Exception,e:        print str(e)#根據索引擷取Excel表格中的資料   參數:file:Excel檔案路徑     colnameindex:表頭列名所在行的所以  ,by_index:表的索引def excel_table_byindex(file= ‘file.xls‘,colnameindex=0,by_index=0):    data = open_excel(file)    table = data.sheets()[by_index]    nrows = table.nrows #行數    ncols = table.ncols #列數    colnames =  table.row_values(colnameindex) #某一行資料     list =[]    for rownum in range(1,nrows):         row = table.row_values(rownum)         if row:             app = {}             for i in range(len(colnames)):                app[colnames[i]] = row[i]              list.append(app)    return list#根據名稱擷取Excel表格中的資料   參數:file:Excel檔案路徑     colnameindex:表頭列名所在行的所以  ,by_name:Sheet1名稱def excel_table_byname(file= ‘file.xls‘,colnameindex=0,by_name=u‘Sheet1‘):    data = open_excel(file)    table = data.sheet_by_name(by_name)    nrows = table.nrows #行數     colnames =  table.row_values(colnameindex) #某一行資料     list =[]    for rownum in range(1,nrows):         row = table.row_values(rownum)         if row:             app = {}             for i in range(len(colnames)):                app[colnames[i]] = row[i]             list.append(app)    return listdef main():   tables = excel_table_byindex()   for row in tables:       print row   tables = excel_table_byname()   for row in tables:       print rowif __name__=="__main__":    main()

 

python操作Excel表格讀寫--xlrd 模組

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.