【Python工具】Excle 讀寫 (使用 xlrd 和 xlrt)


一、安裝 xlrd 和xlwt 模塊

直接通過pip安裝

pip install xlrd
pip install xlwt

二、操作使用

import xlrd
#打開excel
data = xlrd.open_workbook('demo.xls') #注意這里的workbook首字母是小寫
查看文件中包含sheet的名稱
data.sheet_names()
得到第一個工作表,或者通過索引順序 或 工作表名稱
table = data.sheets()[0]
table = data.sheet_by_index(0)
table = data.sheet_by_name(u'Sheet1')
獲取行數和列數
nrows = table.nrows
ncols = table.ncols
獲取整行和整列的值(數組)
table.row_values(i)
table.col_values(i)
循環行,得到索引的列表
for rownum in range(table.nrows):
print table.row_values(rownum)
單元格
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
ctype = 1 # 類型 0 empty,1 string, 2 number, 3 date, 4 boolean, 5 error
value = 'lixiaoluo'
xf = 0 # 擴展的格式化 (默認是0)
table.put_cell(row, col, ctype, value, xf)
table.cell(0,0) # 文本:u'lixiaoluo'
table.cell(0,0).value # 'lixiaoluo'


1、在openwork報錯Debug錯誤信息

#打開excel
data = xlrd.open_workbook('demo.xls') #注意這里的workbook首字母是小寫
Traceback (most recent call last):
  File "D:/PycharmProject/InvestProject/CleanData/excle_data_filter.py", line 6, in <module>
    data = xlrd.open_workbook(u'invest.xls')
  File "D:\Python27\lib\site-packages\xlrd\__init__.py", line 441, in open_workbook
    ragged_rows=ragged_rows,
  File "D:\Python27\lib\site-packages\xlrd\book.py", line 116, in open_workbook_xls
    bk.parse_globals()
  File "D:\Python27\lib\site-packages\xlrd\book.py", line 1158, in parse_globals
    self.handle_sst(data)
  File "D:\Python27\lib\site-packages\xlrd\book.py", line 1129, in handle_sst
    self._sharedstrings, rt_runlist = unpack_SST_table(strlist, uniquestrings)
  File "D:\Python27\lib\site-packages\xlrd\book.py", line 1350, in unpack_SST_table
    nchars = local_unpack('<H', data[pos:pos+2])[0]
struct.error: unpack requires a string argument of length 2

解決方法:

用了個很愚蠢的辦法,把excle 用WPS或者MS Excle打開 然后再保存為另外一份就可以了。

我想我的excle是通過Navicat從Mysql中導出來的,格式不對應吧。

 

 

###我想修改excle表的內容,可是xlrd是只讀,xlrt是只寫,好麻煩

Python中一般使用xlrd(excel read)來讀取Excel文件,使用xlwt(excel write)來生成Excel文件(可以控制Excel中單元格的格式),需要注意的是,用xlrd讀 取excel是不能對其進行操作的:xlrd.open_workbook()方法返回xlrd.Book類型,是只讀的,不能對其進行操作。而 xlwt.Workbook()返回的xlwt.Workbook類型的save(filepath)方法可以保存excel文件。因此對於讀取和生成 Excel文件都非常容易處理,但是對於已經存在的Excel文件進行修改就比較麻煩了。不過,還有一個xlutils(依賴於xlrd和xlwt)提供復制excel文件內容和修改文件的功能。其實際也只是在xlrd.Book和xlwt.Workbook之間建立了一個管道而已,如下圖:

 

 

 

 

xlutils.copy模塊的copy()方法實現了這個功能,示例代碼如下:

from xlrd import open_workbook
from xlutils.copy import copy
 
rb = open_workbook('m:\\1.xls') //data
 
#通過sheet_by_index()獲取的sheet沒有write()方法
rs = rb.sheet_by_index(0)//table
 
wb = copy(rb)
 
#通過get_sheet()獲取的sheet有write()方法
ws = wb.get_sheet(0)
ws.write(0, 0, 'changed!')
 
wb.save('m:\\1.xls')

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM