python3中關(guān)于excel追加寫(xiě)入格式被覆蓋問(wèn)題(實(shí)例代碼)
關(guān)于python3中的追加寫(xiě)入excel問(wèn)題,這個(gè)問(wèn)題坑了我?guī)仔r(shí),其實(shí)加一個(gè)參數(shù)即可。
因?yàn)橹坝袑?xiě)好的excel,想追加寫(xiě)入,但是寫(xiě)入后卻只有寫(xiě)入后的單元格格式,之前寫(xiě)的完全消失。
以下是我的代碼
這代碼可以用是我做的一個(gè)爬蟲(chóng)維護(hù)項(xiàng)目:
def times():
User_Agent = 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/54.0.2840.99 Safari/537.36'
headers = {
'User-Agent': User_Agent
}
search_url = 'https://www.cnss.com.cn/u/cms/www/indexJson/bdi_month.json?v=1577414941357'
request = urllib.request.Request(search_url, headers=headers)
response = urllib.request.urlopen(request)
content = response.read().decode('utf-8')
content = ''.join(content)
# print(content)
# index = re.findall('index":"(.*?)"', content) # 獲取指數(shù)
date = re.findall('date":"(.*?)"', content) # 獲取時(shí)間
time = []
i = 0
start_date = date[0].replace('.', '年')
start_date.replace('.', '月')
end_date = date[-1].replace('.', '年')
end_date.replace('.', '月')
# print(index,date,start_date,end_date)
for j in range(int(len(date) / 1)):
temp = date[i:i + 1]
i += 1
time.append(temp)
hears = start_date + '日' + '——' + end_date + '日' + '嘻嘻嘻'
title=['交易日期','干散貨指數(shù)(BDI)','海岬型指數(shù)(BCI)','巴拿馬型指數(shù)(BPI)','超靈便型船運(yùn)價(jià)指數(shù)(BSI)','靈便型船指數(shù)(BHSI)']
sheet1.write_merge(0, 0+0,0,0+5, hears, style)
for ti in range(len(title)):
sheet1.write(1, ti+0, title[ti], style)
for x in range(len(time)):
for y in range(len(time[x])):
sheet1.write(x + 2, 0, time[x][y], style)
f.save('你想放的路徑.xls')
上面的代碼還是可以繼續(xù)使用
標(biāo)題xlwt的缺陷:
xlwt只能創(chuàng)建一個(gè)全新的excel文件,然后對(duì)這個(gè)文件進(jìn)行寫(xiě)入內(nèi)容以及保存。但是大多數(shù)情況下我們希望的是讀入一個(gè)excel文件,然后進(jìn)行修改或追加,這個(gè)時(shí)候就需要xlutils了。
xlutils的簡(jiǎn)單使用:
接下來(lái)的部分就是關(guān)鍵所在了
formatting_info=True這個(gè)參數(shù)能保留原excel格式
def write_excel_xls_append(path, value,u):
index = len(value) # 獲取需要寫(xiě)入數(shù)據(jù)的行數(shù)
workbook = xlrd.open_workbook('./result/30波羅的海干散貨運(yùn)價(jià)指數(shù).xls',formatting_info=True) # 打開(kāi)工作簿
sheets = workbook.sheet_names() # 獲取工作簿中的所有表格
worksheet = workbook.sheet_by_name(sheets[0]) # 獲取工作簿中所有表格中的的第一個(gè)表格
rows_old = worksheet.ncols # 獲取表格中已存在的數(shù)據(jù)的行數(shù)
new_workbook = copy(workbook) # 將xlrd對(duì)象拷貝轉(zhuǎn)化為xlwt對(duì)象
styleS = xlwt.XFStyle()
alignment = xlwt.Alignment()
alignment.horz = xlwt.Alignment.HORZ_CENTER
alignment.vert = xlwt.Alignment.VERT_CENTER
styleS.alignment = alignment
new_worksheet = new_workbook.get_sheet(0) # 獲取轉(zhuǎn)化后工作簿中的第一個(gè)表格
for i in range(0, index):
for j in range(0, len(value[i])):
new_worksheet.write(i+2, u+1, value[i][j],styleS) # 追加寫(xiě)入數(shù)據(jù),注意是從i+rows_old行開(kāi)始寫(xiě)入
new_workbook.save(path) # 保存工作簿
然后你就會(huì)發(fā)現(xiàn)你的excel簡(jiǎn)直完美~~~
總結(jié)
以上所述是小編給大家介紹的python3中關(guān)于excel追加寫(xiě)入格式被覆蓋問(wèn)題,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
如果你覺(jué)得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!
- Python3+Requests+Excel完整接口自動(dòng)化測(cè)試框架的實(shí)現(xiàn)
- python3.7 利用函數(shù)os pandas利用excel對(duì)文件名進(jìn)行歸類
- Python3.6+selenium2.53.6自動(dòng)化測(cè)試_讀取excel文件的方法
- Python3操作Excel文件(讀寫(xiě))的簡(jiǎn)單實(shí)例
- python3實(shí)現(xiàn)mysql導(dǎo)出excel的方法
- Python3 讀、寫(xiě)Excel文件的操作方法
- python3 讀取Excel表格中的數(shù)據(jù)
- python3結(jié)合openpyxl庫(kù)實(shí)現(xiàn)excel操作的實(shí)例代碼
- python3讀取excel文件只提取某些行某些列的值方法
- Python3使用pandas模塊讀寫(xiě)excel操作示例
- Python3讀取Excel數(shù)據(jù)存入MySQL的方法
- 使用python3+xlrd解析Excel的實(shí)例
- Python3讀寫(xiě)Excel文件(使用xlrd,xlsxwriter,openpyxl3種方式讀寫(xiě)實(shí)例與優(yōu)劣)
相關(guān)文章
Django接收post前端返回的json格式數(shù)據(jù)代碼實(shí)現(xiàn)
這篇文章主要介紹了Django接收post前端返回的json格式數(shù)據(jù)代碼實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-07-07
opencv+python實(shí)現(xiàn)圖像矯正
這篇文章主要為大家詳細(xì)介紹了opencv+python實(shí)現(xiàn)圖像矯正,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-08-08
python實(shí)現(xiàn)類似ftp傳輸文件的網(wǎng)絡(luò)程序示例
這篇文章主要介紹了python實(shí)現(xiàn)類似ftp傳輸文件的網(wǎng)絡(luò)程序示例,需要的朋友可以參考下2014-04-04
解決windows下python3使用multiprocessing.Pool出現(xiàn)的問(wèn)題
這篇文章主要介紹了解決windows下python3使用multiprocessing.Pool出現(xiàn)的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-04-04
flask/django 動(dòng)態(tài)查詢表結(jié)構(gòu)相同表名不同數(shù)據(jù)的Model實(shí)現(xiàn)方法
今天小編就為大家分享一篇flask/django 動(dòng)態(tài)查詢表結(jié)構(gòu)相同表名不同數(shù)據(jù)的Model實(shí)現(xiàn)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-08-08
簡(jiǎn)單介紹Python中的len()函數(shù)的使用
這篇文章主要簡(jiǎn)單介紹了Python中的len()函數(shù)的使用,包括在四種情況下的使用小例子,是Python學(xué)習(xí)當(dāng)中的基礎(chǔ)知識(shí),需要的朋友可以參考下2015-04-04
python 進(jìn)程池的兩種不同實(shí)現(xiàn)方法示例
這篇文章主要為大家介紹了python 進(jìn)程池的兩種不同實(shí)現(xiàn)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-05-05
python多線程實(shí)現(xiàn)TCP服務(wù)端
這篇文章主要為大家詳細(xì)介紹了python多線程實(shí)現(xiàn)TCP服務(wù)端,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-09-09
利用python在excel里面直接使用sql函數(shù)的方法
今天小編就為大家分享一篇利用python在excel里面直接使用sql函數(shù)的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-02-02

