python 3.6
首先在cmd下執行安裝指令 xlre和xlwt : pip install xlre pip install xlwt
#-*- coding: utf8 -*-
import xlrd
import xlwt
fname = "dmin.xls"
bk = xlrd.open_workbook(fname)
shxrange = range(bk.nsheets)
try:
sh = bk.sheet_by_name("Sheet1")
except:
print("no sheet in %s named Sheet1" % fname)
#獲取行數
nrows = sh.nrows
#獲取列數
ncols = sh.ncols
print("nrows %d, ncols %d" % (nrows,ncols))
# 獲取第一行第一列數據
cell_value = sh.cell_value(1,0)
print(cell_value)
#print cell_value
# 創建一個Workbook對象,這就相當於創建了一個Excel文件
book = xlwt.Workbook(encoding='utf-8', style_compression=0)
'''
Workbook類初始化時有encoding和style_compression參數
encoding:設置字符編碼,一般要這樣設置:w = Workbook(encoding='utf-8'),就可以在excel中輸出中文了。
默認是ascii。當然要記得在文件頭部添加:
#!/usr/bin/env python
# -*- coding: utf-8 -*-
style_compression:表示是否壓縮,不常用。
'''
#創建一個sheet對象,一個sheet對象對應Excel文件中的一張表格。
# 在電腦桌面右鍵新建一個Excel文件,其中就包含sheet1,sheet2,sheet3三張表
sheet = book.add_sheet('test', cell_overwrite_ok=True)
# 其中的test是這張表的名字,cell_overwrite_ok,表示是否可以覆蓋單元格,其實是Worksheet實例化的一個參數,默認值是False
# 向表test中添加數據
row_list = []
#獲取各行數據
for i in range(0,nrows):
row_data = sh.row_values(i,0)
row_list.append(row_data)
# sheet.write(0, 0, 'EnglishName') # 其中的'0-行, 0-列'指定表中的單元,'EnglishName'是向該單元寫入的內容
sheet.write(i, 0,row_data[0]) # 其中的'0-行, 0-列'指定表中的單元,'row_data[0]'是向該單元寫入的內容
sheet.write(i,1,row_data[2])
print(row_data[2])
# sheet.write(1, 0, 'Marcovaldo')
txt1 = '中文名字'
sheet.write(0, 1, txt1.decode('utf-8')) # 此處需要將中文字符串解碼成unicode碼,否則會報錯
txt2 = '馬可瓦多'
sheet.write(1, 1, txt2.decode('utf-8'))
# 最后,將以上操作保存到指定的Excel文件中
book.save(r'e:\test1.xls') # 在字符串前加r,聲明為raw字符串,這樣就不會處理其中的轉義了。否則,可能會報錯