python使用openpyxl库修改excel表格数据方法
程序员文章站
2022-05-26 14:25:50
1、openpyxl库可以读写xlsx格式的文件,对于xls旧格式的文件只能用xlrd读,xlwt写来完成了。
简单封装类:
from openpyxl imp...
1、openpyxl库可以读写xlsx格式的文件,对于xls旧格式的文件只能用xlrd读,xlwt写来完成了。
简单封装类:
from openpyxl import load_workbook from openpyxl import workbook from openpyxl.chart import barchart, series, reference, barchart3d from openpyxl.styles import color, font, alignment from openpyxl.styles.colors import blue, red, green, yellow class write_excel(object): def __init__(self,filename): self.filename = filename self.wb = load_workbook(self.filename) self.ws = self.wb.active def write(self, coord, value): # eg: coord:a1 self.ws.cell(coord).value = value self.wb.save(self.filename) def merge(self, rangstring): # eg: rangstring:a1:e1 self.ws.merge_cells(rangstring) self.wb.save(self.filename) def cellstyle(self, coord, font, align): cell = self.ws.cell(coord) cell.font = font cell.alignment = align def makechart(self, title, pos, width, height, col1, row1, col2, row2, col3, row3, row4): ''':param title:图表名 pos:图表位置 width:图表宽度 height:图表高度 ''' data = reference(self.ws, min_col=col1, min_row=row1, max_col=col2, max_row=row2) cat = reference(self.ws, min_col=col3, min_row=row3, max_row=row4) chart = barchart3d() chart.title = title chart.width = width chart.height = height chart.add_data(data=data, titles_from_data=true) chart.set_categories(cat) self.ws.add_chart(chart, pos) self.wb.save(self.filename)
简单使用:
1、新建excel文件处理
wb = workbook()#创建工作簿 ws = wb.active#激活工作表 ws1 = wb.create_sheet("mysheet")#创建mysheet表 ws.title = "new title"#表明改为new title ws.sheet_properties.tabcolor = "1072ba"#颜色 ws['a4'] = 4#赋值 d = ws.cell(row=4, column=2, value=10)#赋值 cell_range = ws['a1':'c2']#选择单元格区域 wb.save('test.xlsx')#保存
2、已有excel文件的处理
a、修改excel数据
wr = write_excel('d:\demo.xlsx') wr.write('a2','hello')
b、合并单元格
wr.merge('a1:b3')
c、单元格加入样式,如字体,颜色等属性
单元格b2设置宋体,14号,红色,自动换行,水平居中,垂直居中
font = font(name=u'宋体', size=14, color=red, bold=true) align = alignment(horizontal='center', vertical='center') wr.cellstyle('b2', font, align)
d、创建3d柱状图
rows = [ (none, 2013, 2014), ("apples", 5, 4), ("oranges", 6, 2), ("pears", 8, 3) ] for row in rows: ws.append(row) wr.makechart(u"3d bar chart", 'e5', 12.5, 7, 2, 1, 3, 4, 1, 2, 4)
可以创建3d柱状和折线图表,挺好用的。
官方文档:
以上这篇python使用openpyxl库修改excel表格数据方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。