python操作xlsx文件的包openpyxl实例


Posted in Python onMay 03, 2018

Python扩展库openpyxl,可以操作07版以上的xlsx文件。可以创建工作簿、选择活动工作表、写入单元格数据,设置单元格字体颜色、边框样式,合并单元格,设置单元格背景等等。

需要增加可以颜色进入包安装目录的

your_pthon_path/site-packages/openpyxl/styles

修改colors.py文件下的

COLOR_INDEX = (
 '00000000', '00FFFFFF', '00FF0000', '0000FF00', '000000FF', #0-4
 '00FFFF00', '00FF00FF', '0000FFFF', '00000000', '00FFFFFF', #5-9
 '00FF0000', '0000FF00', '000000FF', '00FFFF00', '00FF00FF', #10-14
 '0000FFFF', '00800000', '00008000', '00000080', '00808000', #15-19
 '00800080', '00008080', '00C0C0C0', '00808080', '009999FF', #20-24
 '00993366', '00FFFFCC', '00CCFFFF', '00660066', '00FF8080', #25-29
 '000066CC', '00CCCCFF', '00000080', '00FF00FF', '00FFFF00', #30-34
 '0000FFFF', '00800080', '00800000', '00008080', '000000FF', #35-39
 '0000CCFF', '00CCFFFF', '00CCFFCC', '00FFFF99', '0099CCFF', #40-44
 '00FF99CC', '00CC99FF', '00FFCC99', '003366FF', '0033CCCC', #45-49
 '0099CC00', '00FFCC00', '00FF9900', '00FF6600', '00666699', #50-54
 '00969696', '00003366', '00339966', '00003300', '00333300', #55-59
 '00993300', '00993366', '00333399', '00333333', 'System Foreground', 'System Background' #60-64
 '00D2B48C', '0087CEFA', '0000BFFF' #自己添加的
)

以00+16进制RGB颜色代码的形式即可

自己写的一个生成xlsx文件的代码:

#!/usr/bin/env python
#-*- coding: utf-8 -*-
import openpyxl
from openpyxl import Workbook
from openpyxl.styles import colors,Font,Border,Side,PatternFill,Alignment
wb = Workbook() #创建工作簿
ws = wb.active #激活工作簿
ws.merge_cells('C3:E3') #合并单元格
ws.merge_cells('C4:E4')
ws.merge_cells('C20:I20')
ws.merge_cells('C21:I21')
left, right, top, bottom = [Side(style='thin', color='000000')]*4 #设置单元格边框属性
border = Border(left=left, right=right, top=top, bottom=bottom) #设置单元格边框格式
fill1 = PatternFill(start_color = 'FFFF00', end_color = 'FFFF00', fill_type = 'solid') #设置单元格背景色
fill2 = PatternFill(start_color = 'D2B48C', end_color = 'D2B48C', fill_type = 'solid')
fill3 = PatternFill(start_color = '00BFFF', end_color = '00BFFF', fill_type = 'solid')
fill4 = PatternFill(start_color = 'FF0000', end_color = 'FF0000', fill_type = 'solid')
align1 = Alignment(horizontal='center', vertical='center') #设置文本对齐
align2 = Alignment(horizontal='left', vertical='center')
for i in range(3,22):
 for col in 'CDEFGHIJK':
 ws[col+str(i)].border = border #给每个单元格设置相应的格式 
 #ws[col+str(3)].fill = fill1
 #ws[col+str(i)].alignment = align
for col in 'CDEFGHIJK':
 ws[col+str(3)].fill = fill1
 ws[col+str(20)].fill = fill3
 ws[col+str(21)].fill = fill4
 for i in range(4,20):
 ws[col+str(i)].fill = fill2
for col in 'CDEFGHIJK':
 ws[col+str(3)].alignment = align1
for i in range(4,22):
 for col in 'CDE':
 ws[col+str(i)].alignment = align2
for col in 'CDEFGHIJK':
 ws[col+str(3)] = 'test1' #单元格赋值
for i in range(3,22):
 for col in 'CDE':
 if i in range(5,20) and col == 'C':
  pass
 else:
  ws[col+str(i)] = 'test2'
for i in range(4,20):
 for col in 'EFGHIJK':
 ws[col+str(i)] = 50
for i in range(20,22):
 for col in 'JK':
 ws[col+str(i)] = 100
wb.save('test.xlsx') #保存文件

单元格字体等也可以使用相应的模块去设置。

以上这篇python操作xlsx文件的包openpyxl实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python命令行参数sys.argv使用示例
Jan 28 Python
Python编写检测数据库SA用户的方法
Jul 11 Python
通过Python来使用七牛云存储的方法详解
Aug 07 Python
python处理html转义字符的方法详解
Jul 01 Python
Python 编码处理-str与Unicode的区别
Sep 06 Python
使用Python写一个小游戏
Apr 02 Python
python爬取微信公众号文章
Aug 31 Python
Python对象与引用的介绍
Jan 24 Python
ML神器:sklearn的快速使用及入门
Jul 11 Python
使用Python生成200个激活码的实现方法
Nov 22 Python
Python实现遗传算法(二进制编码)求函数最优值方式
Feb 11 Python
django 认证类配置实现
Nov 11 Python
对Python字符串中的换行符和制表符介绍
May 03 #Python
pandas数据处理基础之筛选指定行或者指定列的数据
May 03 #Python
Python爬虫实现全国失信被执行人名单查询功能示例
May 03 #Python
Python 解决中文写入Excel时抛异常的问题
May 03 #Python
python 将数据保存为excel的xls格式(实例讲解)
May 03 #Python
python更改已存在excel文件的方法
May 03 #Python
python写入已存在的excel数据实例
May 03 #Python
You might like
一些操作和快捷键的理解和讨论
2020/03/04 星际争霸
使用PHP遍历文件夹与子目录的函数代码
2011/09/26 PHP
基于php设计模式中单例模式的应用分析
2013/05/15 PHP
测试php连接mysql是否成功的代码分享
2014/01/24 PHP
php从memcache读取数据再批量写入mysql的方法
2014/12/29 PHP
用 JavaScript 迁移目录
2006/12/18 Javascript
Javascript 兼容firefox的一些问题
2009/05/21 Javascript
简单实现异步编程promise模式
2015/07/31 Javascript
javascript基础语法学习笔记
2016/01/04 Javascript
完美解决jQuery 鼠标快速滑过后,会执行多次滑出的问题
2016/12/08 Javascript
JavaScript实现256色转灰度图
2017/02/22 Javascript
AngularJS中table表格基本操作示例
2017/10/10 Javascript
解决layui追加或者动态修改的表单元素“没效果”的问题
2019/09/18 Javascript
layer弹出层取消遮罩的方法
2019/09/25 Javascript
[04:29]DOTA2亚洲邀请赛小组赛第一日 TOP10精彩集锦
2015/02/01 DOTA
[02:41]《西雅图我们来了》2015国际邀请赛出征全记录
2015/07/23 DOTA
python实现的重启关机程序实例
2014/08/21 Python
Python创建模块及模块导入的方法
2015/05/27 Python
Tensorflow之Saver的用法详解
2018/04/23 Python
python XlsxWriter模块创建aexcel表格的实例讲解
2018/05/03 Python
详解从Django Rest Framework响应中删除空字段
2019/01/11 Python
在django view中给form传入参数的例子
2019/07/19 Python
python如何安装下载后的模块
2020/07/03 Python
Python数据库封装实现代码示例解析
2020/09/05 Python
HTML5如何实现元素拖拽
2016/03/11 HTML / CSS
html5新增的属性和废除的属性简要概述
2013/02/20 HTML / CSS
html5使用canvas绘制太阳系效果
2014/12/15 HTML / CSS
Java模拟试题
2014/11/10 面试题
家长对孩子评语
2014/01/30 职场文书
计算机专业毕业生自荐信范文
2014/03/06 职场文书
考生诚信考试承诺书
2014/05/23 职场文书
超市店庆活动方案
2014/08/31 职场文书
三下乡个人总结
2015/03/04 职场文书
毕业酒会致辞
2015/07/29 职场文书
80后创业总结的9条职场用人思想,记得收藏
2019/08/13 职场文书
介绍一下28个JS常用数组方法
2022/05/06 Javascript