《Python趣味工具》——ppt的操作(刷题版)

前面我们对PPT进行了一定的操作,并将其中的文字提取到了word文档中。现在就让我们来刷几道题巩固巩固吧!


在这里插入图片描述


文章目录

  • 1. 查看PPT(上)
  • 2. 查看PPT(中)
  • 3. 查看PPT(下)
  • 4. PPT的页码
  • 5. 大学期末考试
  • 6. 查找重复页
  • 7. 用代码写首小诗


1. 查看PPT(上)

由于期末复习的课程很多,每个课程中又包含了一些PPT,小何想能不能通过 input() 函数,实现个性化交互,让同学们通过输入PPT的名称就可以一键提取出对应的文本并写入Word文档呢🤔

那我们通过三道题实现这个功能吧,在本题中,你需要做的是:通过 input() 函数输入 PPT 的页码,就可以找到该页码对应的形状数。

解题步骤:

  1. 读取指定PPT的幻灯片页;

  2. 使用 input() 函数让用户输入 PPT 的页码(这份PPT只有91页哦);

  3. 将输入的页码减去 1 ,作为幻灯片页序列的索引值,并访问其 .shapes 属性;

  4. 格式化字符串输出"第{x}页有{x}个形状"。

示例代码如下:

# 使用from...import从pptx模块中导入Presentation
from pptx import Presentation# 将.pptx文件路径赋值给变量path
path = "/Users/xiaohe/statistics.pptx"# 读取path并赋值给变量pptxFile
pptxFile = Presentation(path)# 访问Presentation中的.slides属性,赋值给slide
slide = pptxFile.slides# 使用input()函数"输入PPT的页码:"
# 将输入的内容进行int()类型转换后,赋值给pageNumber
pageNumber=int(input("输入PPT的页码:"))# 将pageNumber减1,赋值给index
index=pageNumber-1# 将index作为幻灯片页的索引值,并访问.shapes属性赋值给shape
shape=slide[index].shapes# 利用len()函数对选中的PPT页进行形状数统计,并赋值shapeNumber
shapeNumber=len(shape)# print()格式化输出f"第{pageNumber}页有{shapeNumber}个形状"
print(f"第{pageNumber}页有{shapeNumber}个形状")

2. 查看PPT(中)

上一次我们已经实现了输入PPT的页码,就能找到该页码对应的形状数这一功能,那么本次我们就来实现通过input() 函数输入PPT页码来获取该页码下面全部的文本内容吧🤔

解题步骤:

  1. 读取指定PPT的幻灯片页;

  2. 使用 input() 函数让用户输入 PPT 的页码(这份PPT只有91页哦);

  3. 将输入的页码减去 1 ,作为幻灯片页序列的索引值;

  4. 访问PPT每一页里面的全部文本内容,并打印出来;

示例代码如下:

# 使用from...import从pptx模块中导入Presentation
from pptx import Presentation# 将.pptx文件路径赋值给变量path
path = "/Users/xiaohe/statistics.pptx"# 读取path并赋值给变量pptxFile
pptxFile = Presentation(path)# 访问Presentation对象中的.slides属性,赋值给slide
slide = pptxFile.slides# 使用input()函数"输入PPT的页码(1-91):"
# 将输入的内容进行int()类型转换后,赋值给pageNumber
pageNumber=int(input("输入PPT的页码(1-91):"))# 将pageNumber减1,赋值给index
index=pageNumber-1# 将index作为幻灯片页的索引值,把slide[index]赋值给变量slide_s
slide_s=slide[index]# 将index作为幻灯片页的索引值,for循环遍历slide_s的shapes属性
for shape in slide_s.shapes:# 判断单个shape中是否有文本框if shape.has_text_frame == True:# 读取单个shape中的文本框,并赋值给变量textFrametextFrame = shape.text_framefor para in textFrame.paragraphs:for run in para.runs:# 读取文本框中的文本内容,并赋值给变量textstexts=run.text# print()输出textsprint(texts)

3. 查看PPT(下)

我们在前面已经实现了输入PPT的页码,就能找到该页码对应的形状数以及获取该页码下全部的文本内容等功能,那么本次我们就来实现我们的最终目标吧!🥳通过input() 函数输入PPT名称,一键提取出对应的文本并写入Word文档

解题步骤:

  1. 新建一个空白的 Word 文档;

  2. 使用 input() 函数让用户输入 PPT 的名称;

  3. 访问输入名称的 PPT 中每一页样式块文本内容,使用 add_paragraph() 函数添加文案内容到文档当中;

  4. 将 Word 文档至指定路径。

文件夹路径下包含的PPT文件有:
可用性.pptx;
易修改性.pptx
质量属性.pptx

保存路径:/Users/xiaohe/资料.docx

示例代码如下:

# 使用from...import从pptx模块中导入Presentation
from pptx import Presentation# 使用import导入docx
import docx# 新建一个空白Word文档,赋值给变量docxFile
docxFile=docx.Document()# 将文件夹路径赋值给变量path
path = "/Users/xiaohe"# 使用input()函数"输入PPT的名称(可用性/易修改性/质量属性):"
pptName = input("输入PPT的名称(可用性/易修改性/质量属性):")# 将输入的PPT名称构造正确的读取路径并赋值给fileName
fileName = path+"/"+ pptName+".pptx"# 读取fileName并赋值给变量pptxFile
pptxFile = Presentation(fileName)# for循环遍历pptxFile的slides属性
for slide in pptxFile.slides:# for循环遍历slide中.shapes属性for shape in slide.shapes:# 判断单个shape中是否有文本框if shape.has_text_frame == True:# 读取单个shape中的文本框,并赋值给变量textFrametextFrame = shape.text_frame# 按样式块提取文本,并写入Word文档中for para in textFrame.paragraphs:for run in para.runs:                 docxFile.add_paragraph(run.text)# 保存文档到指定路径,并命名为"资料.docx"
docxFile.save("/Users/xiaohe/资料.docx")

4. PPT的页码

通过今天的学习,我们获取到了 PPT 中全部幻灯片页序列,如何获取PPT的总页码呢?🤔

幻灯片页序列中包含所有幻灯片页对象,可以使用 len() 函数得到序列的长度,也就是PPT的总页码数。

fruitList = [“apple”, “banana”, “watermelon”]
print(len(fruitList))
输出结果为:3

示例代码如下:

# 使用from...import从pptx模块中导入Presentation
from pptx import Presentation# 将.pptx文件路径赋值给变量path
path = "/Users/xiaohe/statistics.pptx"# 读取path并赋值给变量pptxFile
pptxFile=Presentation(path)# 在Presentation对象中访问.slides属性,并赋值给slides
slides=pptxFile.slides# 使用len()函数获取slides序列的长度,赋值给变量page
page=len(slides)# print()格式化输出f"PPT一共有{page}页"
print(f"PPT一共有{page}页")

5. 大学期末考试

期末考试即将到来,小何开始根据PPT整理复习提纲。然而《软件体系结构》这门课程的PPT太多,依次整理其中的文本内容太麻烦啦😥

下面我们就来实现通过 input() 函数输入PPT名称,输出该PPT下的全部文本内容。

解题步骤:

  1. 使用 input() 函数让用户输入 PPT 的名称;

  2. 通过"+“,拼接文件路径;
    文件路径:文件夹路径+”/“+输入名称+”.pptx"

  3. 访问输入名称的PPT中每一页里面的全部文本内容,并打印出来;

文件夹路径下包含的PPT的名称为:
可用性
易修改性
质量属性

示例代码如下:

# 使用from...import从pptx模块中导入Presentation
from pptx import Presentation# 将文件夹路径赋值给变量path
path = "/Users/xiaohe"# 使用input()函数"输入PPT的名称(可用性/易修改性/质量属性):"
# 赋值给pptName
pptName=input("输入PPT的名称(可用性/易修改性/质量属性):")# 构造PPT读取路径并赋值给fileName
fileName=path+"/"+pptName+".pptx"# 读取fileName并赋值给变量pptxFile
pptxFile=Presentation(fileName)# for循环遍历pptxFile的slides属性,赋值给slide
for slide in pptxFile.slides:# for循环遍历slide中.shapes属性,赋值给shapefor shape in slide.shapes:# 判断每个shape中是否有文本框if shape.has_text_frame:# 读取单个shape中的文本框,并赋值给变量textFrametextFrame = shape.text_frame# 读取文本框中的文本内容,并赋值给变量textstexts = textFrame.text# print()输出textsprint(texts) # 有的文件只能这样输出,不用run

6. 查找重复页

由于很多PPT在制作时不小心会存在重复页,小何想能不能通过什么办法快速找出来PPT当中有哪两页是重复的呢🤔

那让我们一起来实现这个功能吧,在本题中,你需要做的是:

  1. 读取指定路径的PPT;

  2. 以幻灯片页为单位,将文本全部提取出;

  3. 定义一个新字典添加键值对,页码为键对应的值为本页文本内容;

  4. 接下来进行逐页查找,如果查找内容与指定内容相同,并且页码不相同,就格式化字符串输出"第x页和第x页重复"。

示例代码如下:

# 使用from...import从pptx模块中导入Presentation
from pptx import Presentation# 将.pptx文件路径赋值给变量path
path = "/Users/xiaohe/可用性.pptx"# 读取path并赋值给变量pptxFile
pptxFile = Presentation(path)# 定义一个空字典dict_all
dict_all={}# 定义变量pageNumber = 1
pageNumber = 1# for循环遍历pptxfile中的.slides属性
for slide in pptxFile.slides:# 定义一个空字符串textSlidetextSlide=""# for循环遍历slide中.shapes属性for shape in slide.shapes:# 判断单个shape中是否有文本框if shape.has_text_frame == True:# 把单个形状下的全部文本赋值给变量textstexts = shape.text# textSlide累加textstextSlide+=texts# 向字典dict_all添加键值对,pageNumber为键,对应值为textSlidedict_all[pageNumber]=textSlide# pageNumber累加1pageNumber += 1# 变量i设置为1
i = 1# while循环如果i<13
while i<13:# 变量check_k设置为icheck_k=i# check_v设置为dict_all[i]check_v=dict_all[i]# for循环遍历dict_all.items(),并赋值给key, valuefor key,value in dict_all.items():# 如果value等于check_vif value==check_v:# 如果key小于check_kif key<check_k:# 格式化字符串输出# f"第{key}页和第{check_k}页重复"print(f"第{key}页和第{check_k}页重复")# i累加1i += 1

7. 用代码写首小诗

刚学完如何用 Python 将文字写入 Word 文档的你快来写一首小诗送给秋天吧!

文案内容为:

月落乌啼霜满天
江枫渔火对愁眠
姑苏城外寒山寺
夜半钟声到客船

你需要完成:

  1. 新建一个空白的 Word 文档;

  2. 使用 input() 函数输入诗句;

  3. 使用 add_paragraph() 函数添加文案内容到文档当中;

  4. 将 Word 文档至指定路径。

保存路径:/Users/qu/诗句.docx

示例代码如下:

import docx
dox=docx.Document()for num in range(4):poem=input("poem:")dox.add_paragraph(poem)
dox.save("/Users/qu/诗句.docx")   

贺中秋,迎国庆!双节快乐!!!

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/90676.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

安防监控/视频汇聚平台EasyCVR云端录像不展示是什么原因?该如何解决?

视频云存储/安防监控EasyCVR视频汇聚平台基于云边端智能协同&#xff0c;支持海量视频的轻量化接入与汇聚、转码与处理、全网智能分发、视频集中存储等。音视频流媒体视频平台EasyCVR拓展性强&#xff0c;视频能力丰富&#xff0c;具体可实现视频监控直播、视频轮播、视频录像、…

Excel技巧之【锁定工作簿】

Excel工作簿是Excel工作区中一个或多个工作表的集合&#xff0c;我们知道Excel可以设置锁定工作表&#xff0c;防止意外或被他人修改&#xff0c;但可能有小伙伴不知道&#xff0c;Excel工作簿也同样可以设置锁定&#xff0c;防止更改。 那工作簿锁定后会怎么样呢&#xff1f;…

【数据结构】顺序查找,折半查找,分块查找的知识点总结及相应的代码实现

目录 1、顺序查找 定义及步骤 代码实现 2、折半查找 定义及步骤 代码实现 折半查找判定树 3、分块查找 定义及步骤 1、顺序查找 定义及步骤 顺序查找的定义&#xff1a;从数据集合的起始位置开始&#xff0c;逐一比较每个数据元素&#xff0c;直到找到所要查找…

uni-app 实现凸起的 tabbar 底部导航栏

效果图 在 pages.json 中设置隐藏自带的 tabbar 导航栏 "custom": true, // 开启自定义tabBar(不填每次原来的tabbar在重新加载时都回闪现) 新建一个 custom-tabbar.vue 自定义组件页面 custom-tabbar.vue <!-- 自定义底部导航栏 --> <template><v…

react.js在visual code 下的hello World

想学习reacr.js &#xff0c;就开始做一个hello world。 我的环境是visual code &#xff0c;所以我找这个环境下的例子。参照&#xff1a; https://code.visualstudio.com/docs/nodejs/reactjs-tutorial 要学习react.js &#xff0c;还得先安装node.js&#xff0c;我在visual …

github代码提交过程详细介绍

1、下载github上面的代码 &#xff08;1&#xff09;在github网站上&#xff0c;找到想要下载的代码仓库界面&#xff0c;点击Code选项就可以看到仓库的git下载地址&#xff1b; &#xff08;2&#xff09;使用命令下载&#xff1a;git clone 地址&#xff1b; 2、配置本地git…

【通意千问】大模型GitHub开源工程学习笔记(1)

9月25日&#xff0c;阿里云开源通义千问140亿参数模型Qwen-14B及其对话模型Qwen-14B-Chat,免费可商用。 立马就到了GitHub去fork。 GitHub&#xff1a; GitHub - QwenLM/Qwen: The official repo of Qwen (通义千问) chat & pretrained large language model proposed b…

在vue使用wangEditor(简单使用)

wangEditor不同的版本使用方法都不一样&#xff0c;这里以目前最新的参考官网方法使用2023-09-28 首先安装&#xff0c;参考官网&#xff0c;注意editor跟editor-for-vue两个都要装 yarn add wangeditor/editor # 或者 npm install wangeditor/editor --saveyarn add wangedit…

【Linux指令集】---git命令的基本使用

个人主页&#xff1a;兜里有颗棉花糖 欢迎 点赞&#x1f44d; 收藏✨ 留言✉ 加关注&#x1f493;本文由 兜里有颗棉花糖 原创 收录于专栏【Linux专栏】&#x1f388; 本专栏旨在分享学习Linux的一点学习心得&#xff0c;欢迎大家在评论区讨论&#x1f48c; 演示环境&#xff1…

Event Loop——事件循环

JS 是单线程的&#xff0c;也就是同一个时刻只能做一件事情。 那么思考&#xff1a;为什么浏览器可以同时执行异步任务呢&#xff1f;因为浏览器是多线程的。 当 JS 需要执行异步任务时&#xff0c;浏览器会另外启动一个线程去执行该任务。 也就是说&#xff0c;“JS 是单线程…

Springboot中slf4j日志的简单应用

1、注入依赖&#xff08;pom.xml&#xff09; <!-- https://mvnrepository.com/artifact/org.slf4j/slf4j-api --> <dependency><groupId>org.slf4j</groupId><artifactId>slf4j-api</artifactId><version>2.0.9</version> &…

【5G PHY】物理层逻辑和物理天线的映射

博主未授权任何人或组织机构转载博主任何原创文章&#xff0c;感谢各位对原创的支持&#xff01; 博主链接 本人就职于国际知名终端厂商&#xff0c;负责modem芯片研发。 在5G早期负责终端数据业务层、核心网相关的开发工作&#xff0c;目前牵头6G算力网络技术标准研究。 博客…

最新AI创作系统源码ChatGPT源码+附详细搭建部署教程+AI绘画系统+支持国内AI提问模型

一、AI系统介绍 SparkAi创作系统是基于国外很火的ChatGPT进行开发的Ai智能问答系统。本期针对源码系统整体测试下来非常完美&#xff0c;可以说SparkAi是目前国内一款的ChatGPT对接OpenAI软件系统。那么如何搭建部署AI创作ChatGPT&#xff1f;小编这里写一个详细图文教程吧&am…

数学术语之源——纤维(fiber)

1. 数学术语“纤维”(英英“fibre”,美英“fiber”)在数学中的起源 fiber[ˈfaɪbə(r)]这个词始于14世纪晚期&#xff0c;词义为“肝叶的一瓣(a lobe of the liver)”,也指“内脏(entrails)”。来自中世纪拉丁语“fibre”,其又源自拉丁语“fibra”,词义为“纤维(a fiber)、细…

31.链表练习题(2)(王道2023数据结构2.3.7节16-25题)

【前面使用的所有链表的定义在第29节】 试题16&#xff1a;两个整数序列A&#xff0c;B存在两个单链表中&#xff0c;设计算法判断B是否是A的连续子序列。 bool Pattern(LinkList L1,LinkList L2){ //此函数实现比较L1的子串中是否有L2LNode *p, *q; //工作在L1,p记录L1子串…

springcloud之自我介绍

写在前面 在这篇文章 中我们分析了单体应用的问题&#xff0c;以及用来解决这些问题的解决的方案微服务&#xff0c;并接着看了微服务需要考虑的各种&#xff0c;如服务调用&#xff0c;负载均衡&#xff0c;服务治理&#xff0c;链路追踪&#xff0c;分布式事务&#xff0c;等…

【IDEA】使用idea调试时查看对象集合的值

1、在实体类上添加toString方法 2、在要查看集合的地方右键View as→toString 3、View Text复制对象集合的值 4、复制map集合的值同理

《动手学深度学习 Pytorch版》 7.6 残差网络(ResNet)

import torch from torch import nn from torch.nn import functional as F from d2l import torch as d2l7.6.1 函数类 如果把模型看作一个函数&#xff0c;我们设计的更强大的模型则可以看作范围更大的函数。为了使函数能逐渐靠拢到最优解&#xff0c;应尽量使函数嵌套&…

Qt 画自定义饼图统计的例子

先给出结果图&#xff0c;这个例子是将各种事件分类然后统计的其比例&#xff0c;然后画饼图显示出来 这个是我仿照官方给的例子&#xff0c;让后自己理解后&#xff0c;修改的&#xff0c;要生成饼图&#xff0c;需要QT的 charts 支持&#xff0c;安装QT 没有选择这个的&#…

【sgUploadTileImage】自定义组件:浏览器端生成瓦片图,并转换为File文件序列上传瓦片图

特性&#xff1a; 支持自定义瓦片图尺寸支持显示预览最小尺寸100x100像素大小&#xff0c;切换为实际切割尺寸支持获取切割后的文件Files数组 sgUploadTileImage源码 <template><div :class"$options.name"><div class"sg-ctrl"><di…