1. 程式人生 > 程式設計 >Python xlrd excel檔案操作程式碼例項

Python xlrd excel檔案操作程式碼例項

開啟檔案

import xlrd
data = xlrd.open_workbook('路徑')

獲取檔案中所有工作表的名稱。

data.sheet_names()

相當於進入檔案中的一個工作表。

table = data.sheet_by_name('Sheet1')

檢視工作表一共有幾行

rowNum = table.nrows

檢視工作表一共有幾列

colNum = table.ncols

檢視第一行所有的名稱。

farst = table.row_values(0)

檢視第一列所有的名稱(其中包含合併單元格的)

farst = table.col_values(0)


檢視讀取內容的格式:(int型別)0empty,1string,2number,3date,4boolean,5error

小應用:

將檔案內的內容按照對應關係一一對應,並將空的去除,判斷是否有int型別,如果有將轉換。

Python xlrd excel檔案操作程式碼例項

#!/usr/bin/env python
# _*_ coding:utf-8 _*_
# __author__ = 'XinBing'
 
import xlrd
data = xlrd.open_workbook('D:\python\交通費報銷單.xlsx')
#開啟檔案
# data.sheet_names()
# #獲取檔案中所有工作表的名稱。
table = data.sheet_by_name('Sheet1')
#相當於進入檔案中的一個工作表。
rowNum = table.nrows
#檢視工作表一共有幾行  10
colNum = table.ncols
#檢視工作表一共有幾列  3
farst = table.row_values(0)
#檢視第一行所有的名稱。
 
#簡單將檔案第一行的數值和第二行一一對應,並新增到字典中,最後新增到列表中。
lis = []
for i in range(1,rowNum):
  #第二行開始迴圈。
  dic = {}
  for i2 in range(colNum):
    #第一列開始。
    data = table.cell_value(i,i2)
    dic[farst[i2]] = data if table.cell(i,i2).ctype != 2 else int(data)
    #   #判斷型別是否為數字型別。針對迴圈出來的行數和列數將內容打印出來。
  for k,y in dic.items():
  # 判斷字典內容裡有沒有包含空的元素,如果有就不寫入到字典中。預設是全部寫入
    if not y:
      dic= {}
      break
  if dic :
    lis.append(dic)
print(lis)
 
#[{'費用名稱': '火車票','金額(元)': 921,'單據張數': 2},{'費用名稱': '油票','金額(元)': 3306,'單據張數': 13},{'費用名稱': '合計','金額(元)': 4227,'單據張數': 15}]

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。