python使用xlrd模組讀寫Excel檔案的方法

來源:互聯網
上載者:User
本文執行個體講述了python使用xlrd模組讀寫Excel檔案的方法。分享給大家供大家參考。具體如下:

一、安裝xlrd模組

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

二、使用介紹

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 ,sys import xlrd def 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 list def main():  tables = excel_table_byindex()  for row in tables:    print row  tables = excel_table_byname()  for row in tables:    print row if __name__=="__main__":   main()

希望本文所述對大家的Python程式設計有所協助。

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.