大量的數(shù)據(jù)處理起來總是讓人頭疼,既內(nèi)容雜亂還要分類,所以用xlwt和xlrd庫解決是個不錯的選擇。
問題:
把大量數(shù)據(jù)寫入excel表格(工作簿),數(shù)據(jù)分成三類,每一類放進一個sheet。
參照了一個教程,這里用的是xlwt和xlrd。
發(fā)現(xiàn)新建sheet的時候,前幾個sheet都被清空,內(nèi)容被覆蓋掉了,所以在此作了調(diào)整,設置全局變量xls_file,用于存儲工作簿。
尤其注意以下兩行代碼,修復了這個問題:
rb = xlrd.open_workbook(path, formatting_info=True)
workbook = copy(rb)
以下是完整代碼:
import xlrd
import xlwt
from xlutils.copy import copy
global xls_file
xls_file = xlwt.Workbook()
def write_field_xls(path, sheet_name, value):
# path:工作簿的路徑,sheet_name:第一個sheet的名稱,value二維數(shù)組,表示插入excel的數(shù)據(jù)
# 第一次建立工作簿時候調(diào)用
index = len(value) # 獲取需要寫入數(shù)據(jù)的行數(shù)
# workbook = xlwt.Workbook() # 新建一個工作簿
workbook = xls_file
sheet = workbook.add_sheet(sheet_name) # 在工作簿中新建一個表格
for i in range(0, index):
for j in range(0, len(value[i])):
sheet.write(i, j, value[i][j]) # 像表格中寫入數(shù)據(jù)(對應的行和列)
workbook.save(path) # 保存工作簿
print("xls格式表格寫入數(shù)據(jù)成功!")
def write_sheet_xls(path, sheet_name, value):
# 新建sheet的時候進行調(diào)用
index = len(value) # 獲取需要寫入數(shù)據(jù)的行數(shù)
# workbook = xlwt.Workbook() # 新建一個工作簿
rb = xlrd.open_workbook(path, formatting_info=True)
workbook = copy(rb)
sheet = workbook.add_sheet(sheet_name) # 在工作簿中新建一個表格
填寫下面表單即可預約申請免費試聽java課程!害怕學不會?助教全程陪讀,隨時解惑!擔心就業(yè)?一地學習,可全國推薦就業(yè)!
for i in range(0, index):
for j in range(0, len(value[i])):
sheet.write(i, j, value[i][j]) # 像表格中寫入數(shù)據(jù)(對應的行和列)
workbook.save(path) # 保存工作簿
print("xls格式表格寫入數(shù)據(jù)成功!")
def write_excel_xls_append(path, value, sheet_index=0):
# 新增數(shù)據(jù)的時候調(diào)用
global xls_file
global info_index
index = len(value) # 獲取需要寫入數(shù)據(jù)的行數(shù)
workbook = xlrd.open_workbook(path) # 打開工作簿
# workbook = xls_file
sheets = workbook.sheet_names() # 獲取工作簿中的所有表格
worksheet = workbook.sheet_by_name(sheets[sheet_index]) # 獲取工作簿中所有表格中的的第一個表格
rows_old = worksheet.nrows # 獲取表格中已存在的數(shù)據(jù)的行數(shù)
new_workbook = copy(workbook) # 將xlrd對象拷貝轉化為xlwt對象
new_worksheet = new_workbook.get_sheet(sheet_index) # 獲取轉化后工作簿中的第一個表格
for i in range(0, index):
for j in range(0, len(value[i])):
new_worksheet.write(i+rows_old, j, value[i][j]) # 追加寫入數(shù)據(jù),注意是從i+rows_old行開始寫入
new_workbook.save(path) # 保存工作簿
info_index += 1
print(info_index, "----追加---sheet--", sheet_index)
以上就是Python中xlwt和xlrd新建sheet表格的方法。
初級會計職稱中級會計職稱經(jīng)濟師注冊會計師證券從業(yè)銀行從業(yè)會計實操統(tǒng)計師審計師高級會計師基金從業(yè)資格稅務師資產(chǎn)評估師國際內(nèi)審師ACCA/CAT價格鑒證師統(tǒng)計資格從業(yè)
一級建造師二級建造師消防工程師造價工程師土建職稱房地產(chǎn)經(jīng)紀人公路檢測工程師建筑八大員注冊建筑師二級造價師監(jiān)理工程師咨詢工程師房地產(chǎn)估價師 城鄉(xiāng)規(guī)劃師結構工程師巖土工程師安全工程師設備監(jiān)理師環(huán)境影響評價土地登記代理公路造價師公路監(jiān)理師化工工程師暖通工程師給排水工程師計量工程師
執(zhí)業(yè)藥師執(zhí)業(yè)醫(yī)師衛(wèi)生資格考試衛(wèi)生高級職稱護士資格證初級護師主管護師住院醫(yī)師臨床執(zhí)業(yè)醫(yī)師臨床助理醫(yī)師中醫(yī)執(zhí)業(yè)醫(yī)師中醫(yī)助理醫(yī)師中西醫(yī)醫(yī)師中西醫(yī)助理口腔執(zhí)業(yè)醫(yī)師口腔助理醫(yī)師公共衛(wèi)生醫(yī)師公衛(wèi)助理醫(yī)師實踐技能內(nèi)科主治醫(yī)師外科主治醫(yī)師中醫(yī)內(nèi)科主治兒科主治醫(yī)師婦產(chǎn)科醫(yī)師西藥士/師中藥士/師臨床檢驗技師臨床醫(yī)學理論中醫(yī)理論