欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python實(shí)現(xiàn)提取或替換PPT中文本與圖片的示例代碼

 更新時(shí)間:2023年01月29日 14:50:08   作者:虛壞叔叔  
這篇文章主要為大家詳細(xì)介紹了Python如何實(shí)現(xiàn)提取保存ppt中的圖片和替換ppt模板的文本,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下

提取保存ppt中的圖片

如何從pptx中提取所有圖片?用python-pptx輕松實(shí)現(xiàn)圖片提取

從指定的文件夾中,對(duì)所有pptx(注意不是ppt,因?yàn)閮烧呶臋n格式不同)進(jìn)行圖片提取。

提取出來(lái)的圖片,以圖片原有名稱(chēng)作為文件名,如果遇到文件名有相同,則在文件名后隨機(jī)加上數(shù)字,保存位置為程序中設(shè)定的targetPath,如果該目錄不存在的話(huà),則會(huì)先創(chuàng)建一個(gè)。

示例代碼

import os
import re,random
from pptx import Presentation

# coding=gbkimport osimport refrom pptx import Presentationimport random
class ExtractPPTXimg():
    def __init__(self,params): 
        self.errFlag = False 
        self.msg = "" 
        self.sourcePath = params["sourcePath"] 
        if not os.path.exists(self.sourcePath): 
            self.errFlag = True 
            self.msg = "源文件夾不存在!" 
        self.targetPath = params["targetPath"] 
        if not os.path.exists(self.targetPath): 
            os.makedirs(self.targetPath) 
            self.run()

    def run(self): 
        if self.errFlag: 
            print(self.msg) 
            return 
        for file in os.listdir(self.sourcePath): 
            if not file[-4:] == "pptx": 
                continue 
            if re.findall("^~",file): 
                continue 
            
            # 提取圖片 
            self.extractImg(file)
    # 保存pptx中的圖片 
    def extractImg(self,file): 
        fileName,expadName = os.path.splitext(file) 
        prs = Presentation(os.path.join(self.sourcePath,file)) 
        for slide in prs.slides: 
            for shape in slide.shapes: 
                try: 
                    if "image" in shape.image.content_type: 
                        imgName = shape.image.filename 
                        newPath = os.path.join(self.targetPath, fileName) 
                        if not os.path.exists(newPath): 
                            os.makedirs(newPath) 
                            newFile = os.path.join(newPath, imgName) 
                            self.saveImage(newFile,shape.image.blob) 
                except: 
                    continue

    # 保存圖片 
    def saveImage(self,newFile,blob): 
        if os.path.exists(newFile): 
            fileName, expadName = os.path.splitext(newFile) 
            newFile = "{}-{}{}".format(fileName,random.randint(1,1000),expadName) 
        with open(newFile, "wb") as f: 
            f.write(blob) 
            print("已保存{}".format(newFile))

    def __str__(self): 
        return self.msg

if __name__ == '__main__': 
    # 要進(jìn)行提取的pptx的所在目錄 "targetPath":r"K:\伍德春原創(chuàng)視頻\自動(dòng)化\2020-11-10\img", # 提取后的txt文件要保存到的目錄 
    params = { "sourcePath":r"D:\自動(dòng)化", "targetPath":r"D:\自動(dòng)化\img",} 
    newobj = ExtractPPTXimg(params)

替換ppt模板的文本

我要做的就是:利用python自動(dòng)控制ppt,動(dòng)態(tài)修改我們指定的變量參數(shù),

把組合出來(lái)的幻燈片保存為一張張的圖片,然后在這個(gè)基礎(chǔ)上加入批量化!

示例代碼

from pptx import Presentation
from pptx.enum.shapes import MSO_SHAPE_TYPE
 
def ppt_catch_format_text(filename):
    """
    抓取PPT的內(nèi)容,按段落返回
    其中 filename 是PPT文件的路徑
    """
    search_str = '性能探測(cè)器'
    repl_str = '性能探測(cè)器PPT啦qqqqqq'
    prs = Presentation(filename)
    for x in range(len(prs.slides)):
        # ---Only on text-boxes outside group elements---
        for shape in prs.slides[x].shapes:
            if hasattr(shape, "text"):
                if(shape.text.find(search_str))!=-1:
                    text_frame = shape.text_frame
                    cur_texts = text_frame.paragraphs[0].runs
                    for index in range(len(cur_texts)):
                        print(text_frame.paragraphs[0].runs[index].text)
                        if(cur_texts[index].text.find(search_str))!=-1:
                            #print(5566)
                            #print(cur_texts[index].text)
                            cur_text = text_frame.paragraphs[0].runs[index].text
                            new_text = cur_text.replace(str(search_str), str(repl_str))
                            text_frame.paragraphs[0].runs[index].text = new_text
 
        # ---Only operate on group shapes---
        group_shapes = [shp for shp in prs.slides[x].shapes
                        if shp.shape_type ==MSO_SHAPE_TYPE.GROUP]
        #print(group_shapes)
        for group_shape in group_shapes:
            for shape in group_shape.shapes:
                if shape.has_text_frame:
                    if(shape.text.find(search_str))!=-1:
                        text_frame = shape.text_frame
                       # cur_texts = text_frame.paragraphs[0].runs
 
                        for index in range(len(text_frame.paragraphs)):
                            cur_text = text_frame.paragraphs[index].text
                            #print(cur_texts[index].text.encode('utf-8').strip().decode())
                            if(cur_text.find(search_str))!=-1:
                                print(7788)
                                #print(cur_texts[index].text)
                                new_text = cur_text.replace(str(search_str), str(repl_str))
                                text_frame.paragraphs[index].text = new_text
                                #print(cur_text)
    prs.save('D:\自動(dòng)化\ss.pptx')
 
 
 
ppt_catch_format_text(r"D:\自動(dòng)化\課件.pptx")

到此這篇關(guān)于Python實(shí)現(xiàn)提取或替換PPT中文本與圖片的示例代碼的文章就介紹到這了,更多相關(guān)Python PPT文本圖片內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • python調(diào)用動(dòng)態(tài)鏈接庫(kù)的基本過(guò)程詳解

    python調(diào)用動(dòng)態(tài)鏈接庫(kù)的基本過(guò)程詳解

    這篇文章主要介紹了python調(diào)用動(dòng)態(tài)鏈接庫(kù)的基本過(guò)程詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-06-06
  • python Qt5實(shí)現(xiàn)窗體跟蹤鼠標(biāo)移動(dòng)

    python Qt5實(shí)現(xiàn)窗體跟蹤鼠標(biāo)移動(dòng)

    今天小編就為大家分享一篇python Qt5實(shí)現(xiàn)窗體跟蹤鼠標(biāo)移動(dòng),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-12-12
  • Python中的命令行參數(shù)解析工具之docopt詳解

    Python中的命令行參數(shù)解析工具之docopt詳解

    docopt 是一個(gè)用來(lái)解析命令行參數(shù)的工具,當(dāng)想要在 Python 程序后面附加參數(shù)時(shí),就不需要再為此而發(fā)愁了。下面這篇文章主要介紹了Python中命令行參數(shù)解析工具之docopt的相關(guān)資料,介紹的非常詳細(xì),需要的朋友們下面來(lái)一起看看吧。
    2017-03-03
  • Python使用虛擬環(huán)境(安裝下載更新卸載)命令

    Python使用虛擬環(huán)境(安裝下載更新卸載)命令

    這篇文章主要為大家介紹了Python使用虛擬環(huán)境(安裝下載更新卸載)命令,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-11-11
  • Gradio機(jī)器學(xué)習(xí)模型快速部署工具quickstart前篇

    Gradio機(jī)器學(xué)習(xí)模型快速部署工具quickstart前篇

    這篇文章主要為大家介紹了Gradio機(jī)器學(xué)習(xí)模型快速部署工具quickstart準(zhǔn)備原文翻譯,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-04-04
  • 什么是Python包的循環(huán)導(dǎo)入

    什么是Python包的循環(huán)導(dǎo)入

    在本篇文章里小編給大家整理的是關(guān)于什么是Python包的循環(huán)導(dǎo)入的相關(guān)知識(shí)點(diǎn),有興趣的朋友們可以參考下。
    2020-09-09
  • PyMongo安裝使用筆記

    PyMongo安裝使用筆記

    這篇文章主要介紹了PyMongo安裝使用筆記,本文講解使用pip方式安裝PyMongo,并給出一個(gè)pymongo的簡(jiǎn)單使用代碼實(shí)例,需要的朋友可以參考下
    2015-04-04
  • 在Python中實(shí)現(xiàn)貪婪排名算法的教程

    在Python中實(shí)現(xiàn)貪婪排名算法的教程

    這篇文章主要介紹了在Python中實(shí)現(xiàn)貪婪排名算法的教程,也是對(duì)學(xué)習(xí)算法的一個(gè)很好的演示,需要的朋友可以參考下
    2015-04-04
  • Python3 類(lèi)型標(biāo)注支持操作

    Python3 類(lèi)型標(biāo)注支持操作

    這篇文章主要介紹了Python3 類(lèi)型標(biāo)注支持操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • 淺談pandas篩選出表中滿(mǎn)足另一個(gè)表所有條件的數(shù)據(jù)方法

    淺談pandas篩選出表中滿(mǎn)足另一個(gè)表所有條件的數(shù)據(jù)方法

    今天小編就為大家分享一篇淺談pandas篩選出表中滿(mǎn)足另一個(gè)表所有條件的數(shù)據(jù)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-02-02

最新評(píng)論