• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

python3中关于excel追加写入格式被覆盖问题(实例代码)

python 搞代码 4年前 (2022-01-07) 30次浏览 已收录 0个评论

这篇文章主要介绍了python3中关于excel追加写入格式被覆盖问题,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下

关于python3中的追加写入excel问题,这个问题坑了我几小时,其实加一个参数即可。

因为之前有写好的excel,想追加写入,但是写入后却只有写入后的单元格格式,之前写的完全消失。

以下是我的代码

这代码可以用是我做的一个爬虫维护项目:

 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) # 获取指数 date = re.findall('date":"(.*?)"', content) # 获取时间 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(<span style="color:transparent">来源gaodai#ma#com搞*!代#%^码$网</span>len(date) / 1)): temp = date[i:i + 1] i += 1 time.append(temp) hears = start_date + '日' + '――' + end_date + '日' + '嘻嘻嘻' title=['交易日期','干散货指数(BDI)','海岬型指数(BCI)','巴拿马型指数(BPI)','超灵便型船运价指数(BSI)','灵便型船指数(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')

上面的代码还是可以继续使用

标题xlwt的缺陷:

xlwt只能创建一个全新的excel文件,然后对这个文件进行写入内容以及保存。但是大多数情况下我们希望的是读入一个excel文件,然后进行修改或追加,这个时候就需要xlutils了。

xlutils的简单使用:

接下来的部分就是关键所在了

 formatting_info=True这个参数能保留原excel格式 def write_excel_xls_append(path, value,u): index = len(value) # 获取需要写入数据的行数 workbook = xlrd.open_workbook('./result/30波罗的海干散货运价指数.xls',formatting_info=True) # 打开工作簿 sheets = workbook.sheet_names() # 获取工作簿中的所有表格 worksheet = workbook.sheet_by_name(sheets[0]) # 获取工作簿中所有表格中的的第一个表格 rows_old = worksheet.ncols # 获取表格中已存在的数据的行数 new_workbook = copy(workbook) # 将xlrd对象拷贝转化为xlwt对象 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) # 获取转化后工作簿中的第一个表格 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) # 追加写入数据,注意是从i+rows_old行开始写入 new_workbook.save(path) # 保存工作簿

然后你就会发现你的excel简直完美~~~

总结

如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

以上就是python3中关于excel追加写入格式被覆盖问题(实例代码)的详细内容,更多请关注gaodaima搞代码网其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:python3中关于excel追加写入格式被覆盖问题(实例代码)

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址