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判断字符串与大小写转换
Jun 08 Python
python的else子句使用指南
Feb 27 Python
python 捕获 shell/bash 脚本的输出结果实例
Jan 04 Python
老生常谈Python之装饰器、迭代器和生成器
Jul 26 Python
Python进度条实时显示处理进度的示例代码
Jan 30 Python
Python管理Windows服务小脚本
Mar 12 Python
详解Python数据分析--Pandas知识点
Mar 23 Python
python实现微信每日一句自动发送给喜欢的人
Apr 29 Python
numpy数组做图片拼接的实现(concatenate、vstack、hstack)
Nov 08 Python
python利用线程实现多任务
Sep 18 Python
pycharm永久激活超详细教程
Oct 29 Python
Python绘制词云图之可视化神器pyecharts的方法
Feb 23 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
PHP的FTP学习(四)
2006/10/09 PHP
PHP 文件上传全攻略
2010/04/28 PHP
PHP5下$_SERVER变量不再受magic_quotes_gpc保护的弥补方法
2012/10/31 PHP
PHP扩展CURL的用法详解
2014/06/20 PHP
php自定义apk安装包实例
2014/10/20 PHP
如何让div span等元素能响应键盘事件操作指南
2012/11/13 Javascript
js数值和和字符串进行转换时可以对不同进制进行操作
2014/03/05 Javascript
javascript判断css3动画结束 css3动画结束的回调函数
2015/03/10 Javascript
浅谈jquery之on()绑定事件和off()解除绑定事件
2016/10/26 Javascript
JS判断是否手机或pad访问实现方法
2016/12/09 Javascript
基于JavaScript实现的折半查找算法示例
2017/04/14 Javascript
JS实现禁止高频率连续点击的方法【基于ES6语法】
2017/04/25 Javascript
详解vue-router和vue-cli以及组件之间的传值
2017/07/04 Javascript
Vue filter介绍及其使用详解
2017/10/21 Javascript
详细分析JS函数去抖和节流
2017/12/05 Javascript
微信小程序中使用wxss加载图片并实现动画效果
2018/08/13 Javascript
React优化子组件render的使用
2019/05/12 Javascript
JavaScript 严格模式(use strict)用法实例分析
2020/03/04 Javascript
[28:42]Ti4正赛VG vs NEWBEE1
2014/07/19 DOTA
Python爬虫代理IP池实现方法
2017/01/05 Python
Python2.7基于淘宝接口获取IP地址所在地理位置的方法【测试可用】
2017/06/07 Python
python实现时间o(1)的最小栈的实例代码
2018/07/23 Python
解决Python2.7中IDLE启动没有反应的问题
2018/11/30 Python
python爬虫之urllib,伪装,超时设置,异常处理的方法
2018/12/19 Python
Python读取指定日期邮件的实例
2019/02/01 Python
Python代码实现删除一个list里面重复元素的方法
2019/04/02 Python
一文秒懂python读写csv xml json文件各种骚操作
2019/07/04 Python
Python异常继承关系和自定义异常实现代码实例
2020/02/20 Python
世界领先的电子书网站:eBooks.com(在线购买小说、非小说和教科书)
2019/03/30 全球购物
int和Integer有什么区别
2013/05/25 面试题
婚礼司仪主持词
2014/03/14 职场文书
教师党的群众路线教育实践活动学习笔记
2014/11/05 职场文书
自我工作评价范文
2015/03/06 职场文书
设备技术员岗位职责
2015/04/11 职场文书
mysql脏页是什么
2021/07/26 MySQL
python字符串的一些常见实用操作
2022/04/06 Python