在日常向領導匯報工作的時候,PPT使用次數是比較多的,那么,怎么才能提高工作效率,更快的去完成PPT呢?下面,小編就給大家總結了一些代碼實例,希望大家以后在工作中能夠遇到。
在日常工作中,PPT制作是常見的工作,那么慢,怎么快速的進行制作,確是十分考驗人的能力的。
如果我們想要把PPT做的更好看一些,比如去制作創意類PPT,則無法通過自動化的形式生成,因為創意本身具有隨機性,而自動化解決的是重復性工作,所以兩者就會產生一定的沖突。
python-pptx是python處理PPT的一個庫,注重的是讀和寫,無法導出,沒有渲染功能,那么,到底該如何使用呢,下面給讀者一步一步的進行拆解。
第一步,安裝python-pptx庫:
pip3 install-i https://pypi.doubanio.com/simple/python-pptx
ppt里面處理的主要對象一般為文本框,表格,圖片。
每一頁的ppt為一個slide
from pptx import Presentation,util
from pptx.util import Pt,Cm
from pptx.shapes.picture import Picture
#實例化一個ppt對象
ppt=Presentation("./test.pptx")
slide=ppt.slides[0]#第幾頁
然后遍歷查看這一頁ppt中都包含哪些對象:
def rander_template(slide):
for shape in slide.shapes:
if shape.has_text_frame==True:
print("==========================文本框=============================")
print("段落長度:",len(shape.text_frame.paragraphs))
for paragraph in shape.text_frame.paragraphs:
#拼接文字
print("段落包含字段:",len(paragraph.runs))
print(''.join(run.text for run in paragraph.runs))
for i in range(len(paragraph.runs)):
print("run"+str(i)+":"+paragraph.runs<i>.text)
print(shape.text_frame.paragraphs[0].runs[0].text)
shape.text_frame.paragraphs[0].runs[0].text="規則是自由的第一要義"
elif shape.has_table==True:
print("==========================表格==============================")
one_table_data=[]
for row in shape.table.rows:#讀每行
row_data=[]
for cell in row.cells:#讀一行中的所有單元格
cell.text=cell.text if cell.text!=""else"未填寫"
c=cell.text
row_data.append(c)
one_table_data.append(row_data)#把每一行存入表
#用二維列表輸出表格行和列的數據
print(one_table_data)
print("第一個單元格內容:",shape.table.rows[0].cells[0].text)
elif isinstance(shape,Picture):
print("==========================圖片==============================")
index=0
with open(f'{index}.jpg','wb')as f:
f.write(shape.image.blob)
index+=1
文本框對象【text_frame】:
shape.has_text_frame查看是否有文本框對象,有的話查看具體有幾個段落【len(shape.text_frame.paragraphs)】,每個段落又 有多少個run對象【len(paragraph.runs)】
注意:修改run對象的時候,修改run[0],后面的值都會被覆蓋。
表格對象【table】:
table對象還是按照行列值來定位劃分的,eg:table.rows[2]cells[3].text代表第三行第四列的值
圖片對象【Picture】:
插入圖片需要固定圖片的位置,比如:
全部代碼:
def insert_pic(slide):
#需要用到pptx庫的util方法
img_path = './blue.png' # 圖片路徑
# 設置圖片的位置和大小
left = util.Cm(8.04)
top = util.Cm(9.93)
width = util.Cm(15.07)
height = util.Cm(4.06)
# 在頁面中插入圖片
slide.shapes.add_picture(img_path, left, top, width, height)
from pptx import Presentation, util
from pptx.util import Pt,Cm
from pptx.shapes.picture import Picture
ppt = Presentation("./test.pptx")
def rander_template(slide):
for shape in slide.shapes:
if shape.has_text_frame == True:
print("==========================文本框=============================")
print("段落長度:",len(shape.text_frame.paragraphs))
for paragraph in shape.text_frame.paragraphs:
# 拼接文字
print("段落包含字段:",len(paragraph.runs))
print(''.join(run.text for run in paragraph.runs))
for i in range(len(paragraph.runs)):
print("run"+str(i)+":"+paragraph.runs[i].text)
print(shape.text_frame.paragraphs[0].runs[0].text)
shape.text_frame.paragraphs[0].runs[0].text = "規則是自由的第一要義"
elif shape.has_table == True:
print("==========================表格==============================")
one_table_data = []
for row in shape.table.rows: # 讀每行
row_data = []
for cell in row.cells: # 讀一行中的所有單元格
cell.text = cell.text if cell.text != "" else "未填寫"
c = cell.text
row_data.append(c)
one_table_data.append(row_data) # 把每一行存入表
# 用二維列表輸出表格行和列的數據
print(one_table_data)
print("第一個單元格內容:",shape.table.rows[0].cells[0].text)
elif isinstance(shape,Picture):
print("==========================圖片==============================")
index = 0
with open(f'{index}.jpg','wb') as f:
f.write(shape.image.blob)
index += 1
def insert_pic(slide):
img_path = './blue.png' # 圖片路徑
# 設置圖片的位置和大小
left = util.Cm(8.04)
top = util.Cm(9.93)
width = util.Cm(15.07)
height = util.Cm(4.06)
# 在頁面中插入圖片
slide.shapes.add_picture(img_path, left, top, width, height)
if __name__ == "__main__":
slide = ppt.slides[0] #第幾頁
rander_template(slide)
insert_pic(slide)
ppt.save('new.pptx') # 保存為文件
初始ppt:
生成ppt:
關于Python自動生產PPT的文章就為大家介紹到這里了,希望能給大家帶來幫助。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/127545.html
摘要:基于云遷移的三個階段細分為八個主要步驟,評估階段主要包括項目啟動現狀梳理以及應用系統關聯關系分析三個步驟,設計階段包括云架構優化設計和云遷移方案設計,實施階段包括目標架構遷移演練及實施和試運行三個步驟。 在云計算市場規模不斷擴大的大背景下,云遷移的需求越來越大且面臨挑戰。云遷移不是一個遷移軟件工具,而是一種服務。前IBM資深架構師姜亞杰從云遷移的三個階段、四個維度到八個步驟的方法,簡述...
摘要:上班太忙沒時間自己學習很多人認為自己沒有成為技術大牛并不是自己不聰明,也不是自己不努力,而是中國的這個環境下,技術人員加班都太多了,導致自己沒有額外的時間進行學習。 寫在前面 不管是開發、測試、運維,每個技術人員心里多多少少都有一個成為技術大牛的夢,畢竟夢想總是要有的,萬一實現了呢!正是對技術夢的追求,促使我們不斷地努力和提升自己。然而夢想是美好的,現實卻是殘酷的,很多同學在實際工作后...
摘要:我們以請求網絡服務為例,來實際測試一下加入多線程之后的效果。所以,執行密集型操作時,多線程是有用的,對于密集型操作,則每次只能使用一個線程。說到這里,對于密集型,可以使用多線程或者多進程來提高效率。 為了提高系統密集型運算的效率,我們常常會使用到多個進程或者是多個線程,python中的Threading包實現了線程,multiprocessing 包則實現了多進程。而在3.2版本的py...
摘要:作為面試官,我是如何甄別應聘者的包裝程度語言和等其他語言的對比分析和主從復制的原理詳解和持久化的原理是什么面試中經常被問到的持久化與恢復實現故障恢復自動化詳解哨兵技術查漏補缺最易錯過的技術要點大掃盲意外宕機不難解決,但你真的懂數據恢復嗎每秒 作為面試官,我是如何甄別應聘者的包裝程度Go語言和Java、python等其他語言的對比分析 Redis和MySQL Redis:主從復制的原理詳...
閱讀 911·2023-01-14 11:38
閱讀 878·2023-01-14 11:04
閱讀 740·2023-01-14 10:48
閱讀 1982·2023-01-14 10:34
閱讀 942·2023-01-14 10:24
閱讀 819·2023-01-14 10:18
閱讀 499·2023-01-14 10:09
閱讀 572·2023-01-14 10:02