python使用xlrd模塊讀寫Excel文件的方法
本文實例講述了python使用xlrd模塊讀寫Excel文件的方法。分享給大家供大家參考。具體如下:
一、安裝xlrd模塊
到python官網下載http://pypi.python.org/pypi/xlrd模塊安裝,前提是已經安裝了python 環(huán)境。
二、使用介紹
1、導入模塊
2、打開Excel文件讀取數(shù)據(jù)
3、使用技巧
獲取一個工作表
table = data.sheet_by_index(0) #通過索引順序獲取
table = data.sheet_by_name(u'Sheet1')#通過名稱獲取
獲取整行和整列的值(數(shù)組)
table.col_values(i)
獲取行數(shù)和列數(shù)
ncols = table.ncols
循環(huán)行列表數(shù)據(jù)
print table.row_values(i)
單元格
cell_C4 = table.cell(2,3).value
使用行列索引
cell_A2 = table.col(1)[0].value
簡單的寫入
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數(shù)據(jù)。
# -*- 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)
#根據(jù)索引獲取Excel表格中的數(shù)據(jù) 參數(shù):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 #行數(shù)
ncols = table.ncols #列數(shù)
colnames = table.row_values(colnameindex) #某一行數(shù)據(jù)
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
#根據(jù)名稱獲取Excel表格中的數(shù)據(jù) 參數(shù):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 #行數(shù)
colnames = table.row_values(colnameindex) #某一行數(shù)據(jù)
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程序設計有所幫助。
- python中使用xlrd、xlwt操作excel表格詳解
- 解決python xlrd無法讀取excel文件的問題
- Python xlrd讀取excel日期類型的2種方法
- Python第三方庫xlrd/xlwt的安裝與讀寫Excel表格
- Python中使用第三方庫xlrd來寫入Excel文件示例
- 詳解python中xlrd包的安裝與處理Excel表格
- Python使用xlrd模塊操作Excel數(shù)據(jù)導入的方法
- python讀取excel進行遍歷/xlrd模塊操作
- Python中使用第三方庫xlrd來讀取Excel示例
- 利用Python第三方庫xlrd讀取Excel中數(shù)據(jù)實例代碼
相關文章
Python讀取sqlite數(shù)據(jù)庫文件的方法分析
這篇文章主要介紹了Python讀取sqlite數(shù)據(jù)庫文件的方法,結合實例形式分析了Python引入sqlite3模塊操作sqlite數(shù)據(jù)庫的讀取、SQL命令執(zhí)行等相關操作技巧,需要的朋友可以參考下2017-08-08
詳解Pandas如何高效對比處理DataFrame的兩列數(shù)據(jù)
我們在用?pandas?處理數(shù)據(jù)的時候,經常會遇到用其中一列數(shù)據(jù)替換另一列數(shù)據(jù)的場景。這一類的需求估計很多人都遇到,當然還有其它更復雜的。解決這類需求的辦法有很多,這里我們來推薦幾個2022-09-09

