python使用openpyxl库修改excel表格数据方法


Posted in Python onMay 03, 2018

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)

python使用openpyxl库修改excel表格数据方法

可以创建3d柱状和折线图表,挺好用的。

官方文档:https://openpyxl.readthedocs.io/en/latest/usage.html

以上这篇python使用openpyxl库修改excel表格数据方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
在Python中的Django框架中进行字符串翻译
Jul 27 Python
利用Python查看目录中的文件示例详解
Aug 28 Python
python中通过预先编译正则表达式提高效率
Sep 25 Python
Python字典操作详细介绍及字典内建方法分享
Jan 04 Python
python画柱状图--不同颜色并显示数值的方法
Dec 13 Python
python根据txt文本批量创建文件夹
Dec 08 Python
kafka-python 获取topic lag值方式
Dec 23 Python
python给视频添加背景音乐并改变音量的具体方法
Jul 19 Python
Python logging模块handlers用法详解
Aug 14 Python
使用tensorflow 实现反向传播求导
May 26 Python
python使用BeautifulSoup 解析HTML
Apr 24 Python
pandas时间序列之pd.to_datetime()的实现
Jun 16 Python
python实现跨excel的工作表sheet之间的复制方法
May 03 #Python
Python利用openpyxl库遍历Sheet的实例
May 03 #Python
python实现简单淘宝秒杀功能
May 03 #Python
Python实现的求解最小公倍数算法示例
May 03 #Python
Python实现的求解最大公约数算法示例
May 03 #Python
Python实现的质因式分解算法示例
May 03 #Python
Python绘制3D图形
May 03 #Python
You might like
需要使用php模板的朋友必看的很多个顶级PHP模板引擎比较分析
2008/05/26 PHP
如何使用“PHP” 彩蛋进行敏感信息获取
2013/08/07 PHP
php判断字符串在另一个字符串位置的方法
2014/02/27 PHP
Laravel SQL语句记录方式(推荐)
2016/05/26 PHP
深入理解PHP类的自动载入机制
2016/09/16 PHP
Laravel框架实现多数据库连接操作详解
2019/07/12 PHP
javascript之函数直接量(function(){})()
2007/06/29 Javascript
jQuery 重复加载错误以及修复方法
2014/12/16 Javascript
JS控制弹出新页面窗口位置和大小的方法
2015/03/02 Javascript
JS+CSS实现闪烁字体效果代码
2016/04/05 Javascript
JQuery点击事件回到页面顶部效果的实现代码
2016/05/24 Javascript
Vue.js实战之组件之间的数据传递
2017/04/01 Javascript
react配合antd组件实现的管理系统示例代码
2018/04/24 Javascript
vue内置组件transition简单原理图文详解(小结)
2018/07/12 Javascript
jQuery实现表单动态添加数据并提交的方法
2018/07/19 jQuery
使用layui 渲染table数据表格的实例代码
2018/08/19 Javascript
vue实现鼠标移入移出事件代码实例
2019/03/27 Javascript
webpack+vue-cil 中proxyTable配置接口地址代理操作
2020/07/18 Javascript
Openlayers显示地理位置坐标的方法
2020/09/28 Javascript
[05:03]显微镜下的DOTA2第十期——Ti3豪之超神幽鬼
2014/06/23 DOTA
[01:19:35]DOTA2上海特级锦标赛主赛事日 - 3 败者组第三轮#2Fnatic VS OG第二局
2016/03/05 DOTA
Python使用numpy产生正态分布随机数的向量或矩阵操作示例
2018/08/22 Python
Tesserocr库的正确安装方式
2018/10/19 Python
Python理解递归的方法总结
2019/01/28 Python
Python 字符串、列表、元组的截取与切片操作示例
2019/09/17 Python
pytorch 限制GPU使用效率详解(计算效率)
2020/06/27 Python
在Python中实现字典反转案例
2020/12/05 Python
HTML5移动端开发中的Viewport标签及相关CSS用法解析
2016/04/15 HTML / CSS
澳大利亚在线家具、灯饰和家居装饰店:LivingStyles
2018/11/20 全球购物
如何配置、使用和清除Smarty缓存
2015/12/23 面试题
自荐信怎么写好
2013/11/11 职场文书
文科生自我鉴定
2014/02/15 职场文书
大一新生学期自我评价
2014/04/09 职场文书
党员自评材料范文
2014/12/17 职场文书
明确岗位职责
2015/02/14 职场文书
2015年财务人员工作总结
2015/04/10 职场文书