范文健康探索娱乐情感热点
投稿投诉
热点动态
科技财经
情感日志
励志美文
娱乐时尚
游戏搞笑
探索旅游
历史星座
健康养生
美丽育儿
范文作文
教案论文

python自动化办公之python操作PPT

  1、python-pptx模块简介
  使用python操作PPT,需要使用的模块就是python-pptx,下面来对该模块做一个简单的介绍。这里提前做一个说明:python操作PPT,最好是我们提前设计好自己的一套样式,然后利用进行python进行内容的获取和填充(最主要的功能!),最好是不用使用python代码操作PPT的格式,格式的修改肯定不如我们直接在PPT中修改方便。
  2、模块的安装与导入
  1)模块的安装"Windows用户命令行下输入" pip install python-pptx "Mac用户命令行下输入" pip3 install python-pptx
  2)模块的导入
  这里有一点需要注意的是:安装的库是python-pptx,但是导入的时候却有点不同。  import pptx
  3、python读取PPT文档中的内容
  1)PPT的结构说明
  在使用python操作PPT之前,首先应该清楚PPT的结构,这个对于之后代码的编写很有帮助
  2)获取Slidefrom pptx import Presentation  prs = Presentation("统计学习方法PPT.pptx") for slide in prs.slides:     print(slide)
  结果如下:
  3)获取Shape形状""" import pptx from pptx import Presentation  prs = Presentation("统计学习方法PPT.pptx") for slide in prs.slides:     for shape in slide.shapes:         print(shape) """ 注意:这里得到的Shape对象,并不能看出什么,接着往下看。
  结果如下:
  4)判断每个Shape中是否存在文字shape.has_text_frame :是否有文字  shape.text_frame :获取文字框  import pptx from pptx import Presentation  prs = Presentation("统计学习方法PPT.pptx") for slide in prs.slides:     for shape in slide.shapes:         if shape.has_text_frame:             text_frame = shape.text_frame             print(text_frame.text)
  结果如下:
  5)获取某一页Slide中的内容import pptx from pptx import Presentation  prs = Presentation("统计学习方法PPT.pptx")  for i,slide in enumerate(prs.slides):     if i == 5:         for shape in slide.shapes:             if shape.has_text_frame:                 text_frame = shape.text_frame                 print(text_frame.text)
  结果如下:
  6)获取Shape中的某个Paragraphimport pptx from pptx import Presentation  prs = Presentation("统计学习方法PPT.pptx")  for i,slide in enumerate(prs.slides):     if i == 5:         for shape in slide.shapes:             if shape.has_text_frame:                 text_frame = shape.text_frame                 for paragraph in text_frame.paragraphs:                     print(paragraph.text) """ 注意:该方法和上述4)中的方法一摸一样。上述方法是直接获取Shpae中的文字内容; 下面这个更灵活,先获取每个Shape,然后在获取每个Shape中的paragraph; 下面方式更好:因为我们可以针对paragraph,写一个判断条件,只获取第几个paragraph; """
  结果如下:
  4、利用python像PPT中写入内容
  1)幻灯片模板及占位符的概念
  3)什么是版式?
  这个概念在下面的效果中,会得以体现。其中prs.slide_layouts[]传入0表示获取的是第一个版式,传入1表示获取的是第二个版式,以此类推下去。
  4)添加Slide和内容
  这里就需要使用上述的自定义母版。因为毕竟是使用python操作PPT,我们可以定义好自己想要展示的PPT母版,然后借助代码完成PPT的内容写入操作。
  ① 占位符id的确认import pptx from pptx import Presentation  prs = Presentation("空白.pptx") # prs.slide_layouts[]表示的是ppt中不同的版式 slide = prs.slides.add_slide(prs.slide_layouts[0]) for shape in slide.placeholders:     phf = shape.placeholder_format     print(f"{phf.idx}--{shape.name}--{phf.type}")     shape.text = f"{phf.idx}--{shape.name}--{phf.type}" # 注意:做完这个操作,一定要记得保存一下! prs.save("电子奖状模板.pptx") """ 上述打印结果如下: 0--Title 1--TITLE (1)  这个表示标题占位符,id为0 13--Picture Placeholder 2--PICTURE (18)  这个表示图片占位符,id为13 14--Text Placeholder 3--BODY (2)  这个表示正文内容占位符,id为14 15--Text Placeholder 4--BODY (2)  这个表示正文内容占位符,id为15 我们一定要先知道每个空格的占位符id,才可以进行下面内容的填充。 """
  效果如下:
  ② PPT内容的填写 import pptx from pptx import Presentation  prs = Presentation("空白.pptx") slide = prs.slides.add_slide(prs.slide_layouts[0]) name = slide.placeholders[14] why = slide.placeholders[15]  name.text = "黄同学" why.text = "学习太积极" prs.save("内容填充.pptx")
  效果如下:
  5)添加段落
  ① 占位符id的确认 import pptx from pptx import Presentation  prs = Presentation("finall.pptx") slide = prs.slides.add_slide(prs.slide_layouts[0]) for shape in slide.placeholders:     phf = shape.placeholder_format     print(f"{phf.idx}--{shape.name}--{phf.type}")     shape.text = f"{phf.idx}--{shape.name}--{phf.type}" print("-------------------------------------------") slide = prs.slides.add_slide(prs.slide_layouts[1]) for shape in slide.placeholders:     phf = shape.placeholder_format     print(f"{phf.idx}--{shape.name}--{phf.type}")     shape.text = f"{phf.idx}--{shape.name}--{phf.type}"  prs.save("哈哈.pptx")
  效果如下:
  ② 段落的添加 import pptx from pptx import Presentation  prs = Presentation("finall.pptx") slide = prs.slides.add_slide(prs.slide_layouts[0]) name = slide.placeholders[14] why = slide.placeholders[15] name.text = "黄同学" why.text = "学习太积极" # --------------------------------------------------- # prs1 = Presentation("finall.pptx") slide1 = prs.slides.add_slide(prs.slide_layouts[1]) shapes = slide1.shapes title_shape = shapes.title  # 这句代码可以改为title_shape = shapes.placeholders[0] body_shape = shapes.placeholders[1]  title_shape.text = "这是一个标题"  tf = body_shape.text_frame # 这句代码就是给body占位符添加内容! tf.text = "带圆点的符号1"  p = tf.add_paragraph() # 这个代码表示在原来的基础上,添加第一个段落! p.text = "带圆点的符号2"  p = tf.add_paragraph() # 这个代码表示在原来的基础上,添加第二个段落! p.text = "带圆点的符号3"  prs.save("嘿嘿.pptx")
  效果如下:
  ③ 给段落设定层级关系 import pptx from pptx import Presentation  prs = Presentation("finall.pptx") slide = prs.slides.add_slide(prs.slide_layouts[0]) name = slide.placeholders[14] why = slide.placeholders[15] name.text = "黄同学" why.text = "学习太积极" # --------------------------------------------------- # prs1 = Presentation("finall.pptx") slide1 = prs.slides.add_slide(prs.slide_layouts[1]) shapes = slide1.shapes title_shape = shapes.title  # 这句代码可以改为title_shape = shapes.placeholders[0] body_shape = shapes.placeholders[1]  title_shape.text = "这是一个标题"  tf = body_shape.text_frame tf.text = "带圆点的符号1"  p = tf.add_paragraph() p.text = "带圆点的符号2" # 原始内容的层级相当于是0,因此这个段落我设置为层级1,下面的段落设置为层级2 p.level = 1  p = tf.add_paragraph() p.text = "带圆点的符号3" p.level = 2  prs.save("嘻嘻.pptx")
  效果如下:
  ④ 添加一个文本框slide.shapes.add_textbox(left, top, width, height)  from pptx import Presentation from pptx.util import Cm, Pt  prs = Presentation() # 使用第一个版式 black_slide_layout = prs.slide_layouts[0] slide = prs.slides.add_slide(black_slide_layout)  left = top = width = height = Cm(3) text_box = slide.shapes.add_textbox(left, top, width, height) tf = text_box.text_frame tf.text = "这是一段文本框里面的文字"  p = tf.add_paragraph() p.text = "这是第二段文字,加粗,字号40" p.font.bold = True p.font.size = Pt(40)  prs.save("添加一个文本框0.pptx")
  效果如下:
  ⑤ 添加一个图片slide.shapes.add_picture(图片路径, 距离左边, 距离顶端, 宽度, 高度)
  第一种展示: from pptx import Presentation from pptx.util import Cm  prs = Presentation() # 使用第七个版式 black_slide_layout = prs.slide_layouts[6] slide = prs.slides.add_slide(black_slide_layout)  left = top = Cm(3) pic = slide.shapes.add_picture("孙悟空.png", left, top)  prs.save("添加图片1.pptx")
  效果如下:
  第二种展示: from pptx import Presentation from pptx.util import Cm  prs = Presentation() # 使用第七个版式 black_slide_layout = prs.slide_layouts[6] slide = prs.slides.add_slide(black_slide_layout)  left = top = Cm(3) height = Cm(5.5) pic = slide.shapes.add_picture("孙悟空.png", left, top, height=height)  prs.save("添加图片2.pptx")
  效果如下:
  ⑥ 添加表格shapes.add_table(rows, cols, left, top, width, height)  from pptx import Presentation from pptx.util import Cm, Pt  prs = Presentation() # 使用第七个版式 black_slide_layout = prs.slide_layouts[6] slide = prs.slides.add_slide(black_slide_layout) shapes = slide.shapes  rows, cols = 5, 3 left = top = Cm(5) width = Cm(18) height = Cm(3)  table = shapes.add_table(rows, cols, left, top, width, height).table table.columns[0].width = Cm(6) table.columns[1].width = Cm(2) table.columns[2].width = Cm(2) table.rows[0].height = Cm(2)  data = [     ["姓名","性别","成绩"],     ["张三","男",96],     ["李四","女",87],     ["王五","女",90],     ["赵六","男",78] ]  for row in range(rows):     for col in range(cols):         table.cell(row,col).text = str(data[row][col]) prs.save("插入表格.pptx")
  结果如下:
  5、PPT文档内容样式批量调整
  1)文本框位置的调整
  上面我们已经知道怎么添加文本框,现在我们需要做的就是,怎么调整文本框的位置。  from pptx import Presentation from pptx.util import Cm, Pt from pptx.enum.text import MSO_ANCHOR, MSO_AUTO_SIZE  prs = Presentation() # 使用第七个版式 black_slide_layout = prs.slide_layouts[6] slide = prs.slides.add_slide(black_slide_layout)  left = top = width = height = Cm(3) text_box = slide.shapes.add_textbox(left, top, width, height) tf = text_box.text_frame tf.text = "这是一段文本框里面的文字" # ----------------------------------------- # tf.margin_bottom = Cm(0.1) # 下边距 tf.margin_left = 0 # 下边距 # 一定要导入MSO_ANCHOR这个库 tf.vertical_anchor = MSO_ANCHOR.BOTTOM # 对齐文本方式:底端对齐 tf.word_wrap = True # 框中的文字自动换行  prs.save("文本框样式的调整.pptx")
  结果如下:
  2)文本框背景颜色调整from pptx import Presentation from pptx.util import Cm, Pt from pptx.enum.text import MSO_ANCHOR, MSO_AUTO_SIZE from pptx.dml.color import RGBColor  prs = Presentation() # 使用第七个版式 black_slide_layout = prs.slide_layouts[6] slide = prs.slides.add_slide(black_slide_layout)  left = top = width = height = Cm(3) text_box = slide.shapes.add_textbox(left, top, width, height) tf = text_box.text_frame tf.text = "这是一段文本框里面的文字" # -------------------------------------- # tf.margin_bottom = Cm(0.1) # 下边距 tf.margin_left = 0 # 下边距 tf.vertical_anchor = MSO_ANCHOR.BOTTOM   tf.word_wrap = True # 框中的文字自动换行 # -------------------------------------- # fill = text_box.fill fill.solid() # 使用之前一定要导入RGBColor这个库 fill.fore_color.rgb = RGBColor(247, 150, 70)  prs.save("文本框背景色的调整.pptx")
  结果如下:
  3)文本框边框样式调整from pptx import Presentation from pptx.util import Cm, Pt from pptx.enum.text import MSO_ANCHOR, MSO_AUTO_SIZE from pptx.dml.color import RGBColor  prs = Presentation() # 使用第七个版式 black_slide_layout = prs.slide_layouts[6] slide = prs.slides.add_slide(black_slide_layout)  left = top = width = height = Cm(3) text_box = slide.shapes.add_textbox(left, top, width, height) tf = text_box.text_frame tf.text = "这是一段文本框里面的文字" # -------------------------------------- # tf.margin_bottom = Cm(0.1) # 下边距 tf.margin_left = 0 # 下边距 tf.vertical_anchor = MSO_ANCHOR.BOTTOM   tf.word_wrap = True # 框中的文字自动换行 # -------------------------------------- # fill = text_box.fill fill.solid() # 使用之前一定要导入RGBColor这个库 fill.fore_color.rgb = RGBColor(247, 150, 70) # -------------------------------------- # line = text_box.line line.color.rgb = RGBColor(255, 0, 0) line.width = Cm(0.3)  prs.save("文本框边框样式调整.pptx")
  结果如下:
  4)段落对其调整from pptx import Presentation from pptx.enum.text import PP_ALIGN  prs = Presentation() # 使用第七个版式 black_slide_layout = prs.slide_layouts[6] slide = prs.slides.add_slide(black_slide_layout)  left = top = width = height = Cm(3) text_box = slide.shapes.add_textbox(left, top, width, height) tf = text_box.text_frame # ---------------------------- # p = tf.add_paragraph() p.text = "这是第二段文字" p.alignment = PP_ALIGN.LEFT  prs.save("段落对其调整.pptx")
  当然这里还有一些其他样式的调整,和word很类似,就不一一叙述了。
  5)字体样式调整
  代码如下: from pptx import Presentation from pptx.util import Cm, Pt from pptx.enum.text import MSO_ANCHOR, MSO_AUTO_SIZE from pptx.dml.color import RGBColor from pptx.enum.text import PP_ALIGN  prs = Presentation() # 使用第七个版式 black_slide_layout = prs.slide_layouts[6] slide = prs.slides.add_slide(black_slide_layout)  left = top = width = height = Cm(3) text_box = slide.shapes.add_textbox(left, top, width, height) tf = text_box.text_frame # ---------------------------- # p = tf.add_paragraph() p.text = "这是第二段文字" p.alignment = PP_ALIGN.LEFT # ------------------------------------- # p.font.bold = True p.font.name = "宋体" p.font.color.rgb = RGBColor(247, 150, 70) p.font.size = Pt(30)  prs.save("字体样式调整.pptx")
  结果如下:

发烧的iphone近几年来,苹果的芯片技术已经远远领先同代安卓好几年,这个辉煌的背后,是以大家在使用iPhone时带来的发烧发热为代价带来的。但是,从目前来看,苹果并没有收手的意识,随m1芯片的诞生Realme爆款登场,真我GT大师首战一秒破亿!网友真香7月发布的新机并不多,只有Realme真我GT大师探索版中兴AXON30屏下版和华为P50系列等几款。中兴AXON30屏下版采用维信诺屏幕,搭载骁龙870,8128GB版本的价格为红魔碰瓷Redmi后,新机信息被扒出,网友自取其辱昨天RedmiK40游戏版发布会上,在讲到厚度只有8。3mm,可能是今年最薄的游戏手机时,红魔高管倪飞直接表示8。3mm厚不可能是2021年最薄的游戏手机。难道说红魔也要走大众化外来来回回屏实力,还是Note20Ultra怎么样买一款很贵的手机,又不用担心给老婆责备?可能先给老婆买一台,她就没什么意见了。自2018年我从note5换了国产品牌一加5,然后因觉得屏幕问题换回S10PLUS,再到S20F丢失的酒文化如果不是中国人就很难理解中国的酒文化,喝酒并不是一个简单的强者游戏,酒桌上说了算的,并非是酒量最大的,而多半是位高权重的。本来一桌酒席,就是一个各司其职的游戏,年轻者倒酒,主人陪酒杯面加手柄,还要什么女朋友最近断断续续的通关了战神2,还是很苦逼的,因为用手机的ps2模拟器。奉劝大家,手机玩这些动作游戏务必要帧率优先,画面精度和分辨率什么的就别过多追求了,能保持或者接近60帧比什么都重由电视剧小舍得联想到的女权问题小舍得里,田雨岚一角让我差生了很多的想法,这是一个在一个缺少父爱的家庭里长大的女人,这种经历促成了她不健全的人格。结婚生子后,出于母性的爱,她将自己的感情上的缺失所带来的压力,加倍小伙放开我,网游我要开20个寻找真知派技术技能超级玩家不知道有没有爱玩网游需要多开的小伙伴,客户端开多了会出现蓝屏的情况。造成蓝屏的原因有软件(系统),也有硬件上的。个人经验来看,这是由于CPU不给力负载过高国行PS5上架华为商城,这或许是为MateView显示器预热明天(5月15日)国行PS5将在各大电商平台正式发售,而在今天,华为商城突然宣布,也将上架国行PS5,价格与发布价相同,3899元。从商城页面看,华为商城上架的只有光驱版的PS5,速看荣耀Play5,这款2099起的华为Nova8SE会变香吗?被大家调侃为新安卓机皇的荣耀Play5发布了,由于距离上一次荣耀发布会已经过去4个月的时间,虽然这次是一款千元机,但关注度还是很高的,那么下面就来快速的看看这款机型。荣耀Play5iPhone13系列差异对比,Pro版大翻身,性价比最高iPhone13与iPhone12相比iPhone12主要升级点有处理器,相机,屏幕,电池,内存。处理器,CPU部分A15比A14单核性能提升8,多核性能提升12,GPU(4核)性
智能控制系统介绍智能控制系统的构成是由仪器仪表控制系统信息系统组成,然后再通过优化网络设施和云平台,然后再进行视频监控移动应用安全防护等,涉及范围和功能非常繁杂,近年来,工业互联网技术高速发展,云大事评丨插电混动市场正迎来春天每经记者李星日前,随着新能源汽车补贴逐步退出,加之纯电动车原材料价格的上涨,使得原本就没有盈利甚至亏损的车企面临的成本压力日益加大。为缓解制造成本压力,车企开始转变发展策略,插电混转转手机市场分析3月厂商频发中端机,卖旧换新更省钱春暖花开之际,手机市场也迎来了一波新机发布的高峰。三月中下旬,手机厂商密集发布新款旗舰机型,有三家品牌的新品发布会甚至在同一天撞车。不同于年末年初阶段高端机型为核心看点,这一波新机老美白忙活了!华为再次登顶全球第一,是爱立信和诺基亚之和这3年来,老美总是想尽一切办法针对华为,企图将华为5G技术排挤出国际市场,甚至要求各国一起拒绝华为的5G技术和通信设备。显然老美认为只有彻底打败华为,才能在全球获得5G技术的主导权今日热点1腾讯2021全年研发投入同比增长33至518。8亿元,较2018年实现翻番腾讯发布2021年业绩报告。财报显示,2021全年研发投入同比增长33至518。8亿元,较2018年实现小米传来新消息,雷军值得点赞关键时刻!最近一段时间,英特尔谷歌苹果微软AMD等一大批欧美科技企业的举动,一次又一次地撕开了科技无国界的伪面具。当然,我们也意识到了,科技不但有国界,而且还很深。在这场风波中,我引领运动健康市场潮流,荣耀这两款穿戴设备为何让我爱不释手?如今,随着生活节奏越来越快,尤其是在大城市的年轻人为了事业操劳奔波,往往都会忽略运动的重要性,随之而来年纪轻轻就被肥胖脂肪肝三高所困扰。因此,是时候将健康问题重视起来,是时候放缓奔2022年最佳智能手机2022年最佳智能手机智能手机在日常生活中变得如此重要,以至于一个好的智能手机和一个有很多困难的坏智能手机之间的区别可能会成就或破坏你的整个体验。虽然大多数智能手机都有很多东西可以2022购买智能电视,这几点要注意,别盲目崇外忽略了重点现在都是2022年了,家电市场中仍然不乏会有这样的情况出现到了家电卖场,不说先挑挑逛逛,张嘴就要进口的,国产品牌一律不看。如果好言相劝几句,推荐几款性价比更高的国产电视机,说不定他老人智能手表的技术现状与未来发展趋势近年来,随着社会老龄化速度加快,老年人口比例越来越高,到2021年底,60岁及以上人口26736万人,占全国人口的18。9,其中65岁及以上人口20056万人,占全国人口的14。2iPhone13ProMax再次降价,128GB版售价再创新低,值得入手吗?当其它品牌手机配备6。8英寸屏幕都只能算是普通水准的时候,苹果公司旗下6。7英寸屏幕iPhone却仍然在用大屏手机作为卖点来进行宣传,不过这也没办法,毕竟苹果手机与其它品牌手机差别