EXCEL VBA 自动添加新幻灯片到 Powerpoint

问题描述 投票:0回答:1

这是我将内容从 Excel 导出到 PowerPoint 的代码。我的问题是演示文稿中只有一张幻灯片。当满足标准时,VBA 应自动增加幻灯片并填充它。幻灯片应具有相同的布局。在每个 IF 和 Else 循环之后,我需要为下一次迭代添加一张新幻灯片。使用此代码我得到一个错误,Active X 组件无法创建对象。有什么帮助吗?

Dim oPPTShape As PowerPoint.Shape
Dim oPPTFile As PowerPoint.Presentation
Dim SlideNum As Integer
Dim pptSlide As PowerPoint.Slide
Dim pptLayout As CustomLayout
Dim strPresPath As String, strExcelFilePath As String, strNewPresPath As String
                strPresPath = "C:\Users\asehgal\Desktop\OPL\Presentation1.pptx"

            On Error Resume Next
            Set oPPTApp = GetObject(, "PowerPoint.Application")

                If oPPTApp Is Nothing Then



                Set oPPTApp = CreateObject("PowerPoint.Application")
                oPPTApp.Visible = True 'msoTrue

                End If
                On Error GoTo 0
                Set oPPTFile = oPPTApp.Presentations.Open(strPresPath)
                SlideNum = 1
                oPPTFile.Slides(SlideNum).Select
                Set oPPTShape = oPPTFile.Slides(SlideNum).Shapes("Table 1")

                On Error Resume Next
                If oPPTApp.Windows.Count > 0 Then
                Set oPPTFile = oPPTApp.ActivePresentation

                Set pptSlide = oPPTFile.Slides(oPPTApp.ActiveWindow.Selection.SlideRange.SlideIndex)
                Else

                    Set oPPTFile = oPPTApp.Presentations.Add

                    Set pptSlide = oPPTFile.Slides.AddSlide(1, ppLayout)
                End If
                On Error GoTo 0      
                Do
            'if topics are same
            If (arrThema(p, 0) = arrThema(p + 1, 0)) Then

                With oPPTShape.Table
                .cell(1, 1).Shape.TextFrame.TextRange.text = arrThema(p, 0)
                'if true Adda new slide here for the next iteration
                End With

                'If subtopics are also same
                If (arrThema(p, 1) = arrThema(p + 1, 1)) Then


                Else 'if subtopics are different

                With oPPTShape.Table

                .cell(2, 1).Shape.TextFrame.TextRange.text = arrThema(p, 1)
                .cell(3, 2).Shape.TextFrame.TextRange.text = Beschreibung(p)
                'if true Add a new slide here for the next iteration            
                End With

                oPPTFile.Slides(SlideNum).Select
                Set oPPTShape = oPPTFile.Slides(SlideNum).Shapes("Table 1")
                With oPPTShape.Table
                .cell(2, 1).Shape.TextFrame.TextRange.text = arrThema(p + 1, 1)
                .cell(3, 2).Shape.TextFrame.TextRange.text = Beschreibung(p + 1)
                'if true Adda new slide here for the next iteration

                End With

               ' MsgBox "Description : " & Beschreibung(p)
                End If


                Else


                'add a new slide here and add the details there
                With oPPTShape.Table
                .cell(1, 1).Shape.TextFrame.TextRange.text = arrThema(p, 0)
                .cell(2, 1).Shape.TextFrame.TextRange.text = arrThema(p, 1)
                .cell(3, 2).Shape.TextFrame.TextRange.text = Beschreibung(p)

    'if true Adda new slide here for the next iteration

                    'code for adding a new slide which does not work
                Set pptLayout = ActivePresentation.Slides(1).CustomLayout
               Set pptSlide = ActivePresentation.Slides.AddSlide(2, pptLayout)

                End With



            End If
            p = p + 1
           Loop Until p = noThema
vba excel powerpoint
1个回答
0
投票

无论您需要插入新幻灯片,都可以使用此代码,它将将该幻灯片添加到演示文稿的末尾并应用您的自定义布局

Set pptSlide = oPPTApp.Slides.AddSlide(oPPTApp.Slides.Count + 1, pptLayout) 

编辑

抱歉,我无法亲自测试。尝试上面编辑的代码

© www.soinside.com 2019 - 2024. All rights reserved.