有一组任务数据,要把它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完整版相关推荐

  1. Java操作大数据量Excel导入导出万能工具类(完整版)

    Java操作大数据量Excel导入导出万能工具类(完整版) 转载自:https://blog.csdn.net/JavaWebRookie/article/details/80843653 更新日志: ...

  2. python接口自动化测试框架实战从设计到开发_【B0753】[java视频教程]Python接口自动化测试框架设计到开发完整版视频教程 it教程...

    Java视频教程名称:Python接口自动化测试框架设计到开发完整版视频教程   java自学网[javazx.com]  Python视频教程   it教程 Java自学网收集整理 java论坛&q ...

  3. 计算机科学领域外文期刊影响因子排行,2020最新SCI影响因子出炉,中国期刊Top100榜单公布,附最全EXCEL完整版目录!...

    Hello,大家好,我是伊曼! 后台有不少咨询,最新论文影响因子的, 其实前期我们介绍过一个便捷工具-IF查与投, 往期内容: 当然,为了方便大家查阅,此处对其进行重新介绍同时,对2020最新影响因子 ...

  4. 2023年SCI期刊最新影响因子发布Excel完整版下载(亲测可下载)

    2023年 SCI期刊  最新影响因子  发布   Excel   完整版  下载   (亲测可下载) 北京时间6月28日,2023年最新SCI影响因子(Impact Factor,IF)正式出炉.科 ...

  5. python数据导出excel_python 数据生成excel导出(xlwt,wlsxwrite)代码实例

    这篇文章主要介绍了python 数据生成excel导出(xlwt,wlsxwrite)代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 话不多 ...

  6. python sql导出excel_python sql导出excel数据库

    数据库内容到EXCEL 继Python将数据库数据导入到EXCEL文章之后,这次来一个推进版,将其编写为函数,接着是class.哈哈.. 问过群里的朋友,他们大多采用工具将数据导入到excel,本人以 ...

  7. python新手教程全套_Python入门教程完整版(懂中文就能学会)

    前几天给大家分享视频<python基础教程>受到了广泛的关注,有人不知道怎么领取,居然称小编为"骗子". 不过小编的内心是强大的,网友虐我千百遍,我待网友如初恋,因为今 ...

  8. python文件目录管理 项目_Python入门教程完整版(懂中文就能学会)

    今天给大家带来了干货,Python入门教程完整版,完整版啊!完整版! 言归正传,小编该给大家介绍一下这套教程了,希望每个小伙伴都沉迷学习,无法自拔 本套教程学习时间15天 1-3天内容:为Linux基 ...

  9. python xlwt写入excel_python xlwt写入excel操作

    原博文 2018-11-14 15:51 − 安装 $ pip install xlwt 例子: import xlwt # 创建一个workbook 设置编码 workbook = xlwt.Wor ...

最新文章

  1. 计算机网络(本科)形成性,《计算机组网技术》作业形考网考形成性考核-国家开放大学电大本科...
  2. 格式android id,android 获取APP的唯一标识applicationId的实例
  3. Access denied for user 'root'@'localhost' (using password: YES)的解决
  4. POJ 3159[差分约束]
  5. c语言随机产生arp报文,c语言构造arp报文
  6. jpa 动态查询条件 数组_Spring data jpa 复杂动态查询方式总结
  7. 【转】使用 vim + ctags + cscope + taglist 阅读源码
  8. Topic model相关文章总结
  9. 网络编程之OSI七层协议略析
  10. 在Unity编辑器中开发遇到问题BUG如何调试解决?
  11. CCF NOI1075 F函数
  12. 计算机重置指令,如何利用指令重置Win7网络设置
  13. Must specify unique android:id, android:tag, or have a parent with an id for 异常
  14. 定义结构体的三种方法(C语言)
  15. 拉普拉斯(Laplace)变换——自控笔记系列(一)
  16. “看得见的手”:浅谈我国网约车监管
  17. 国内CDN的排名情况
  18. 高德地图实现逻辑及代码
  19. 什么是 CSRF 攻击?如何防范 CSRF 攻击?
  20. php如何实现备忘录,备忘录模式及php实现

热门文章

  1. Hadoop学习与使用
  2. php集群管理自动采集cns,CNS平台集成Expect自动化脚本配置功能
  3. android 通知栏歌词,状态栏歌词插件下载
  4. 全球计算机科学研究生排名,新|美国计算机科学研究生专业世界排名靠50强名单...
  5. 什么是内网/局域网,局域网管控软件有什么用...
  6. 微博季报图解:营收4.8亿美元 净利受滴滴与天下秀拖累
  7. Android开发者网址大全(不定期更新)
  8. mysql数据库表缩表_不会写复杂的SQL,该怎么学习?
  9. 河海大学软件工程学硕考研复试经验贴
  10. Altium Designer的几种常用布线技巧