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发送SMTP邮件的教程
Apr 29 Python
Python中title()方法的使用简介
May 20 Python
python 2.7.14安装图文教程
Apr 08 Python
python 将md5转为16字节的方法
May 29 Python
python实现猜单词小游戏
May 22 Python
flask框架中勾子函数的使用详解
Aug 01 Python
Pycharm+django2.2+python3.6+MySQL实现简单的考试报名系统
Sep 05 Python
基于python实现蓝牙通信代码实例
Nov 19 Python
浅析Django 接收所有文件,前端展示文件(包括视频,文件,图片)ajax请求
Mar 09 Python
浅谈Keras的Sequential与PyTorch的Sequential的区别
Jun 17 Python
Python OpenCV快速入门教程
Apr 17 Python
Python实现生活常识解答机器人
Jun 28 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如何防止用户重复提交表单
2020/12/09 PHP
JavaScript QueryString解析类代码
2010/01/17 Javascript
javascript获取当前日期时间及其它操作函数
2011/01/11 Javascript
JavaScript中window、doucment、body的解释
2013/08/14 Javascript
直接在JS里创建JSON数据然后遍历使用
2014/07/25 Javascript
浅谈javascript对象模型和function对象
2014/12/26 Javascript
JavaScript中的数值范围介绍
2014/12/29 Javascript
js动态修改表格行colspan列跨度的方法
2015/03/30 Javascript
javascript实现控制的多级下拉菜单
2015/07/05 Javascript
原生js实现可拖动的登录框效果
2017/01/21 Javascript
Javascript实现信息滚动效果
2017/05/18 Javascript
详解react-webpack2-热模块替换[HMR]
2017/08/03 Javascript
Javascript(es2016) import和require用法和区别详解
2017/08/11 Javascript
js排序与重组的实例讲解
2017/08/28 Javascript
用最简单的方法判断JavaScript中this的指向(推荐)
2017/09/04 Javascript
微信小程序 搜索框组件代码实例
2019/09/06 Javascript
微信小程序订阅消息(java后端实现)开发
2020/06/01 Javascript
[01:00:53]2018DOTA2亚洲邀请赛3月29日 小组赛B组 iG VS Secret
2018/03/30 DOTA
分析Python的Django框架的运行方式及处理流程
2015/04/08 Python
Python的Django框架使用入门指引
2015/04/15 Python
Python3 适合初学者学习的银行账户登录系统实例
2017/08/08 Python
python定向爬虫校园论坛帖子信息
2018/07/23 Python
详解Django CAS 解决方案
2019/10/30 Python
Python网络爬虫四大选择器用法原理总结
2020/06/01 Python
使用css实现android系统的loading加载动画
2019/07/25 HTML / CSS
html5借用repeating-linear-gradient实现一把刻度尺(ruler)
2019/09/09 HTML / CSS
华为俄罗斯官方网上商城:购买Huawei手机和平板
2017/04/21 全球购物
印度在线内衣和时尚目的地:Zivame
2017/09/28 全球购物
美国正宗奢华复古手袋、珠宝及配饰网站:What Goes Around Comes Around
2018/07/21 全球购物
应届生煤化工求职信
2013/10/21 职场文书
什么样的创业计划书可行性高?
2014/02/01 职场文书
企业年检委托书范本
2014/10/14 职场文书
2014高三学生考试作弊检讨书
2014/12/14 职场文书
财务统计员岗位职责
2015/04/14 职场文书
关于Python中进度条的六个实用技巧分享
2022/04/05 Python
浅谈css清除浮动(clearfix和clear)的用法
2023/05/21 HTML / CSS