python生成矩阵导出excel_Python xlwt导出excel完整版
有一组任务数据,要把它excel下载下来,如果仅仅导出,用csv导出就很方便。
但是要导出漂亮的样式,重复的地方要合并单元格,设置背影颜色,字体,边框等。而CSV是纯文本格式,不支持设置各种样式。
研究了一天,把代码写了出来。
完整代码如下:
import xlwt
book = xlwt.Workbook(encoding='utf-8')
sheet = book.add_sheet('sheetname')
def set_style(color='white', height=260, bold=False):
#: 设置单元格字体
style = xlwt.XFStyle()
font = xlwt.Font()
# font.name = name
font.bold = bold
font.color_index = 4
font.height = height
style.font = font
# 设置单元格背景颜色
pattern = xlwt.Pattern()
pattern.pattern = xlwt.Pattern.SOLID_PATTERN
pattern.pattern_fore_colour = xlwt.Style.colour_map[color]
style.pattern = pattern
#:设置单元格边框线条
borders = xlwt.Borders() # Create Borders
# May be: NO_LINE, THIN, MEDIUM, DASHED, DOTTED, THICK, DOUBLE, HAIR,
# MEDIUM_DASHED, THIN_DASH_DOTTED, MEDIUM_DASH_DOTTED,
# THIN_DASH_DOT_DOTTED, MEDIUM_DASH_DOT_DOTTED,
# SLANTED_MEDIUM_DASH_DOTTED, or 0x00 through 0x0D.
borders.left = xlwt.Borders.THIN
borders.right = xlwt.Borders.THIN
borders.top = xlwt.Borders.THIN
borders.bottom = xlwt.Borders.THIN
style.borders = borders # Add Borders to Style
#: 设置单元格居中格式
alignment = xlwt.Alignment() # Create Alignment
# May be: HORZ_GENERAL, HORZ_LEFT, HORZ_CENTER, HORZ_RIGHT, HORZ_FILLED,
# HORZ_JUSTIFIED, HORZ_CENTER_ACROSS_SEL, HORZ_DISTRIBUTED
alignment.horz = xlwt.Alignment.HORZ_CENTER # 横向居中
alignment.vert = xlwt.Alignment.VERT_CENTER # 纵向居中 May be: VERT_TOP, VERT_CENTER, VERT_BOTTOM, VERT_JUSTIFIED, VERT_DISTRIBUTED
alignment.wrap = xlwt.Alignment.WRAP_AT_RIGHT # :自动换行
style.alignment = alignment
return style
#:模拟数据
data = [
{
"goal_id": 17,
"goal_name": "\u5b9e\u73b0OKR\u4e0e\u4efb\u52a1\u7ba1\u7406\u7cfb\u7edf\u4e0a\u7ebf\u4e14\u672c\u7ec4\u5185\u65e5\u5e38\u5316\u4f7f\u7528",
"goal_progress": 0,
"name": "\u589e\u52a0\u76ee\u6807\u3001\u4efb\u52a1\u7684\u5ef6\u671f\u63d0\u9192\u4e0e\u5c55\u793a\u3002",
"owner": "aaron.yang",
"progress": 0,
"result_id": 26,
"result_name": "\u5b8c\u6210\u4efb\u52a1\u3001OKR\u3001\u62a5\u8868\u3001\u7ee9\u6548\u529f\u80fd\u6a21\u5757\u5f00\u53d1\u4e0e\u4e0a\u7ebf",
"result_progress": 0,
},
{
"goal_id": 17,
"goal_name": "\u5b9e\u73b0OKR\u4e0e\u4efb\u52a1\u7ba1\u7406\u7cfb\u7edf\u4e0a\u7ebf\u4e14\u672c\u7ec4\u5185\u65e5\u5e38\u5316\u4f7f\u7528",
"goal_progress": 0,
"name": "task2",
"owner": "aaron.yang",
"progress": 0,
"result_id": 26,
"result_name": "\u5b8c\u6210\u4efb\u52a1\u3001OKR\u3001\u62a5\u8868\u3001\u7ee9\u6548\u529f\u80fd\u6a21\u5757\u5f00\u53d1\u4e0e\u4e0a\u7ebf",
"result_progress": 0,
},
{
"goal_id": 17,
"goal_name": "\u5b9e\u73b0OKR\u4e0e\u4efb\u52a1\u7ba1\u7406\u7cfb\u7edf\u4e0a\u7ebf\u4e14\u672c\u7ec4\u5185\u65e5\u5e38\u5316\u4f7f\u7528",
"goal_progress": 0,
"name": "task3",
"owner": "aaron.yang",
"progress": 0,
"result_id": 26,
"result_name": "\u5b8c\u6210\u4efb\u52a1\u3001OKR\u3001\u62a5\u8868\u3001\u7ee9\u6548\u529f\u80fd\u6a21\u5757\u5f00\u53d1\u4e0e\u4e0a\u7ebf",
"result_progress": 0,
},
]
# 写入第一行数据
row0 = ['目标名称', '目标进度', '关键结果名称', '关键结果进度', '任务名称', '任务负责人', '任务进度']
sheet.write_merge(0, 0, 0, 3, 'OKR', set_style('purple_ega', height=500))
sheet.write_merge(0, 0, 4, 6, '任务', set_style('cyan_ega', height=500))
# 写入第二行数据
for i in range(0, len(row0)):
sheet.write(1, i, row0[i], set_style('sky_blue'))
# 把需要合并的单元格,统计要合并多少行,以key,value形式缓存起来。
goal_tmp = {}
result_tmp = {}
for task in data:
if task['goal_id'] not in goal_tmp:
goal_tmp[task['goal_id']] = 1
else:
goal_tmp[task['goal_id']] += 1
if task['result_id'] not in result_tmp:
result_tmp[task['result_id']] = 1
else:
result_tmp[task['result_id']] += 1
goal_ids = []
result_ids = []
for index, task in enumerate(data):
index = index + 1
row_start = 1 + index
#: 如果已合并单元格,把id追加到列表,避免重复合并
if task['goal_id'] not in goal_ids:
row_end = index + goal_tmp[task['goal_id']]
sheet.write_merge(row_start, row_end, 0, 0, task['goal_name'], set_style())
sheet.write_merge(row_start, row_end, 1, 1, task['goal_progress'], set_style())
goal_ids.append(task['goal_id'])
if task['result_id'] not in result_ids:
row_end = index + result_tmp[task['result_id']]
sheet.write_merge(row_start, row_end, 2, 2, task['result_name'], set_style())
sheet.write_merge(row_start, row_end, 3, 3, task['result_progress'], set_style('yellow'))
result_ids.append(task['result_id'])
# 写入接下来的几列数据,并根据关键的列设置背景颜色
sheet.write(row_start, 4, task['name'], set_style())
sheet.write(row_start, 5, task['owner'], set_style())
sheet.write(row_start, 6, task['progress'], set_style('yellow'))
#: 设置单元格宽度
sheet.col(0).width = 10000
sheet.col(2).width = 10000
sheet.col(3).width = 4000
sheet.col(4).width = 10000
sheet.col(5).width = 5000
#:写入到文件
book.save('/tmp/bookname.xls')
python生成矩阵导出excel_Python xlwt导出excel完整版相关推荐
- Java操作大数据量Excel导入导出万能工具类(完整版)
Java操作大数据量Excel导入导出万能工具类(完整版) 转载自:https://blog.csdn.net/JavaWebRookie/article/details/80843653 更新日志: ...
- python接口自动化测试框架实战从设计到开发_【B0753】[java视频教程]Python接口自动化测试框架设计到开发完整版视频教程 it教程...
Java视频教程名称:Python接口自动化测试框架设计到开发完整版视频教程 java自学网[javazx.com] Python视频教程 it教程 Java自学网收集整理 java论坛&q ...
- 计算机科学领域外文期刊影响因子排行,2020最新SCI影响因子出炉,中国期刊Top100榜单公布,附最全EXCEL完整版目录!...
Hello,大家好,我是伊曼! 后台有不少咨询,最新论文影响因子的, 其实前期我们介绍过一个便捷工具-IF查与投, 往期内容: 当然,为了方便大家查阅,此处对其进行重新介绍同时,对2020最新影响因子 ...
- 2023年SCI期刊最新影响因子发布Excel完整版下载(亲测可下载)
2023年 SCI期刊 最新影响因子 发布 Excel 完整版 下载 (亲测可下载) 北京时间6月28日,2023年最新SCI影响因子(Impact Factor,IF)正式出炉.科 ...
- python数据导出excel_python 数据生成excel导出(xlwt,wlsxwrite)代码实例
这篇文章主要介绍了python 数据生成excel导出(xlwt,wlsxwrite)代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 话不多 ...
- python sql导出excel_python sql导出excel数据库
数据库内容到EXCEL 继Python将数据库数据导入到EXCEL文章之后,这次来一个推进版,将其编写为函数,接着是class.哈哈.. 问过群里的朋友,他们大多采用工具将数据导入到excel,本人以 ...
- python新手教程全套_Python入门教程完整版(懂中文就能学会)
前几天给大家分享视频<python基础教程>受到了广泛的关注,有人不知道怎么领取,居然称小编为"骗子". 不过小编的内心是强大的,网友虐我千百遍,我待网友如初恋,因为今 ...
- python文件目录管理 项目_Python入门教程完整版(懂中文就能学会)
今天给大家带来了干货,Python入门教程完整版,完整版啊!完整版! 言归正传,小编该给大家介绍一下这套教程了,希望每个小伙伴都沉迷学习,无法自拔 本套教程学习时间15天 1-3天内容:为Linux基 ...
- python xlwt写入excel_python xlwt写入excel操作
原博文 2018-11-14 15:51 − 安装 $ pip install xlwt 例子: import xlwt # 创建一个workbook 设置编码 workbook = xlwt.Wor ...
最新文章
- 计算机网络(本科)形成性,《计算机组网技术》作业形考网考形成性考核-国家开放大学电大本科...
- 格式android id,android 获取APP的唯一标识applicationId的实例
- Access denied for user 'root'@'localhost' (using password: YES)的解决
- POJ 3159[差分约束]
- c语言随机产生arp报文,c语言构造arp报文
- jpa 动态查询条件 数组_Spring data jpa 复杂动态查询方式总结
- 【转】使用 vim + ctags + cscope + taglist 阅读源码
- Topic model相关文章总结
- 网络编程之OSI七层协议略析
- 在Unity编辑器中开发遇到问题BUG如何调试解决?
- CCF NOI1075 F函数
- 计算机重置指令,如何利用指令重置Win7网络设置
- Must specify unique android:id, android:tag, or have a parent with an id for 异常
- 定义结构体的三种方法(C语言)
- 拉普拉斯(Laplace)变换——自控笔记系列(一)
- “看得见的手”:浅谈我国网约车监管
- 国内CDN的排名情况
- 高德地图实现逻辑及代码
- 什么是 CSRF 攻击?如何防范 CSRF 攻击?
- php如何实现备忘录,备忘录模式及php实现
热门文章
- Hadoop学习与使用
- php集群管理自动采集cns,CNS平台集成Expect自动化脚本配置功能
- android 通知栏歌词,状态栏歌词插件下载
- 全球计算机科学研究生排名,新|美国计算机科学研究生专业世界排名靠50强名单...
- 什么是内网/局域网,局域网管控软件有什么用...
- 微博季报图解:营收4.8亿美元 净利受滴滴与天下秀拖累
- Android开发者网址大全(不定期更新)
- mysql数据库表缩表_不会写复杂的SQL,该怎么学习?
- 河海大学软件工程学硕考研复试经验贴
- Altium Designer的几种常用布线技巧