本文主要介绍如何通过python生成ppt文件,以及借助ppt模板来生成ppt
环境
python 3
python-pptx
安装
1
|
pip3 install python - pptx
|
将文字输出到ppt
效果图
代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
from pptx import Presentation
# 创建幻灯片 ------
prs = Presentation()
title_slide_layout = prs.slide_layouts[ 0 ]
slide = prs.slides.add_slide(title_slide_layout)
title = slide.shapes.title
subtitle = slide.placeholders[ 1 ]
# 设置标题和副标题
title.text = "Hello, World!"
subtitle.text = "pip install python-pptx"
prs.save( "test.pptx" )
|
图表输出到ppt
效果图
代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
from pptx import Presentation
from pptx.chart.data import ChartData
from pptx.enum.chart import XL_CHART_TYPE
from pptx.util import Inches
# 创建幻灯片 ------
prs = Presentation()
slide = prs.slides.add_slide(prs.slide_layouts[ 5 ])
# 定义图表数据 ---------------------
chart_data = ChartData()
chart_data.categories = [ 'East' , 'West' , 'Midwest' ]
chart_data.add_series( 'Series 1' , ( 19.2 , 21.4 , 16.7 ))
# 将图表添加到幻灯片 --------------------
x, y, cx, cy = Inches( 2 ), Inches( 2 ), Inches( 6 ), Inches( 4.5 )
slide.shapes.add_chart(
XL_CHART_TYPE.COLUMN_CLUSTERED, x, y, cx, cy, chart_data
)
prs.save( 'chart-01.pptx' )
|
使用ppt模板来生成ppt
- 准备ppt模板(网络下载或自定义幻灯片母版)
- 加载ppt模板,并使用指定幻灯片样式
- 添加数据并生成新ppt
效果图
代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
|
from pptx import Presentation
from pptx.util import Inches
from pptx import Presentation
from pptx.chart.data import ChartData
from pptx.enum.chart import XL_CHART_TYPE
from pptx.util import Cm #Inches
from pptx.enum.chart import XL_LEGEND_POSITION
if __name__ = = '__main__' :
# 创建幻灯片 ------
prs = Presentation( 'template.pptx' )
title_only_slide_layout = prs.slide_layouts[ 5 ]
slide = prs.slides.add_slide(title_only_slide_layout)
shapes = slide.shapes
shapes.title.text = '报告'
# 定义表格数据 ------
name_objects = [ "object1" , "object2" , "object3" ]
name_AIs = [ "AI1" , "AI2" , "AI3" ]
val_AI1 = ( 19.2 , 21.4 , 16.7 )
val_AI2 = ( 22.3 , 28.6 , 15.2 )
val_AI3 = ( 20.4 , 26.3 , 14.2 )
val_AIs = [val_AI1, val_AI2, val_AI3]
# 表格样式 --------------------
rows = 4
cols = 4
top = Cm( 12.5 )
left = Cm( 3.5 ) #Inches(2.0)
width = Cm( 24 ) # Inches(6.0)
height = Cm( 6 ) # Inches(0.8)
# 添加表格到幻灯片 --------------------
table = shapes.add_table(rows, cols, left, top, width, height).table
# 设置单元格宽度
table.columns[ 0 ].width = Cm( 6 ) # Inches(2.0)
table.columns[ 1 ].width = Cm( 6 )
table.columns[ 2 ].width = Cm( 6 )
table.columns[ 3 ].width = Cm( 6 )
# 设置标题行
table.cell( 0 , 1 ).text = name_objects[ 0 ]
table.cell( 0 , 2 ).text = name_objects[ 1 ]
table.cell( 0 , 3 ).text = name_objects[ 2 ]
# 填充数据
table.cell( 1 , 0 ).text = name_AIs[ 0 ]
table.cell( 1 , 1 ).text = str (val_AI1[ 0 ])
table.cell( 1 , 2 ).text = str (val_AI1[ 1 ])
table.cell( 1 , 3 ).text = str (val_AI1[ 2 ])
table.cell( 2 , 0 ).text = name_AIs[ 1 ]
table.cell( 2 , 1 ).text = str (val_AI2[ 0 ])
table.cell( 2 , 2 ).text = str (val_AI2[ 1 ])
table.cell( 2 , 3 ).text = str (val_AI2[ 2 ])
table.cell( 3 , 0 ).text = name_AIs[ 2 ]
table.cell( 3 , 1 ).text = str (val_AI3[ 0 ])
table.cell( 3 , 2 ).text = str (val_AI3[ 1 ])
table.cell( 3 , 3 ).text = str (val_AI3[ 2 ])
# 定义图表数据 ---------------------
chart_data = ChartData()
chart_data.categories = name_objects
chart_data.add_series(name_AIs[ 0 ], val_AI1)
chart_data.add_series(name_AIs[ 1 ], val_AI2)
chart_data.add_series(name_AIs[ 2 ], val_AI3)
# 添加图表到幻灯片 --------------------
x, y, cx, cy = Cm( 3.5 ), Cm( 4.2 ), Cm( 24 ), Cm( 8 )
graphic_frame = slide.shapes.add_chart(
XL_CHART_TYPE.COLUMN_CLUSTERED, x, y, cx, cy, chart_data
)
chart = graphic_frame.chart
chart.has_legend = True
chart.legend.position = XL_LEGEND_POSITION.TOP
chart.legend.include_in_layout = False
value_axis = chart.value_axis
value_axis.maximum_scale = 100.0
value_axis.has_title = True
value_axis.axis_title.has_text_frame = True
value_axis.axis_title.text_frame.text = "False positive"
value_axis.axis_title.text_frame.auto_size
prs.save( 'test_template.pptx' )
|
本文用到的源码
利用场景
- 周期性数据汇总及报表生成
- 业务或项目等数据可视化
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:https://www.huuinn.com/archives/524