AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / computer / Perguntas / 1590890
Accepted
sancho.s ReinstateMonicaCellio
sancho.s ReinstateMonicaCellio
Asked: 2020-10-06 04:08:16 +0800 CST2020-10-06 04:08:16 +0800 CST 2020-10-06 04:08:16 +0800 CST

Exporte o Powerpoint para um único PDF, cada página como uma imagem

  • 772

Eu tenho uma apresentação em Powerpoint. Eu quero transformá-lo em um PDF. Se eu salvar uma cópia e usar PDF, há pelo menos dois problemas que desejo evitar:

  1. O texto é selecionável. Talvez isso possa ser evitado por meio das configurações de segurança do arquivo PDF.

  2. Lembro-me de ver ocasionalmente (e é uma pena que não posso reproduzir agora) que o PDF resultante tem pequenos problemas de organização.

Uma maneira de evitar esses problemas é exportar cada slide como uma imagem pura. Eu posso lidar com essa rota, mas há dois pontos que a tornam um tanto complicada, dos quais pretendo me livrar:

  1. Ao exportar do Powerpoint como jpg (por exemplo), não há opção para evitar a exportação de slides ocultos (isso pode ser feito ao salvar diretamente como PDF).

  2. Ao exportar do Powerpoint como jpg (por exemplo), cada slide é exportado separadamente. O encadeamento de todas as imagens em um pdf deve ser feito manualmente.

Existe alguma maneira de atingir meu objetivo? Acho que poderia escrever código VBA para isso, mas não quero reinventar a roda.

pdf microsoft-powerpoint
  • 2 2 respostas
  • 505 Views

2 respostas

  • Voted
  1. Steve Rindsberg
    2020-10-08T13:36:44+08:002020-10-08T13:36:44+08:00

    Salve uma CÓPIA de sua apresentação como uma apresentação de imagem do PowerPoint. Isso lhe dará um PPTX onde cada slide é uma imagem do slide original.

    Não substitua sua apresentação original ao salvá-la. Depois que os slides forem convertidos em imagens, não será possível convertê-los novamente em slides editáveis.

    Certifique-se de que os slides que estavam ocultos no original permaneçam ocultos na apresentação de imagem salva. Caso contrário, convém ocultá-los novamente antes de salvá-los em PDF.

    • 2
  2. Best Answer
    sancho.s ReinstateMonicaCellio
    2020-10-22T04:56:35+08:002020-10-22T04:56:35+08:00

    Após a troca de comentários na resposta de Steve Rindsberg, concluí que o caminho a seguir é com o VBA (o que eu pretendia evitar). Estou postando aqui o código que usei. No momento de escrever o código, ele oferece flexibilidade para adicionar recursos, por exemplo, não exporte slides ocultos.
    Adicionei a concatenação de imagens em um único arquivo PDF (isso também pode ser feito com o Adobe Acrobat, conversor do ImageMagick, etc.)
    Observe que ExportAsFixedFormatrequer ppFixedFormatIntentPrint, caso contrário, a qualidade da saída será perdida novamente.
    Espero que isso seja útil para os outros.

    Sub ppt2images(Optional path As String = "")
        '
        ' If not given, use for the output directory the same as in the original presentation
        '
        On Error GoTo Err_ImageSave
    
        ' Set paths and file names
        Dim oPres As Presentation
        Set oPres = ActivePresentation
        Dim sImagePath As String
        Dim sPrefix As String
        sPrefix = Split(oPres.Name, ".")(0)
        If (path = "") Then
            path = oPres.path
        End If
        sImagePath = path & "\" & sPrefix
        If Dir(sImagePath, vbDirectory) <> vbNullString Then
            'MsgBox "Folder " & sImagePath & " exist"
        Else
            MkDir (sImagePath)
        End If
       
        ' Get current resolution
        Dim ps As PageSetup
        Set ps = oPres.PageSetup
        Dim lScaleWidth As Long '* Scale Width
        Dim lScaleHeight As Long '* Scale Height
        lScaleWidth = ps.SlideWidth
        lScaleHeight = ps.SlideHeight
        Dim ar As Double
        ar = lScaleWidth / lScaleHeight
        
        ' Set target resolution
        Dim newWidth As Long '* Scale Width
        Dim newHeight As Long '* Scale Height
        newWidth = 4096
        newHeight = newWidth / ar
        
        ' Create new temporary presentation to add generated images as slides
        Dim oPresTmp As Presentation
        ' Create it as not visible
        Set oPresTmp = Presentations.Add(msoFalse)
        ' Copy page size from the source presentation
        With oPresTmp.PageSetup
            .SlideHeight = oPres.PageSetup.SlideHeight
            .SlideWidth = oPres.PageSetup.SlideWidth
        End With
        Dim oSlideNew As Slide '* Slide Object
        Dim oPic As Shape
    
        ' Export slides
        Dim sImageName As String
        Dim oSlide As Slide '* Slide Object
        Dim img_format As String
        img_format = "png"
        For Each oSlide In oPres.Slides
            With oSlide
                ' If slide is not hidden
                If (.SlideShowTransition.Hidden = msoFalse) Then
                    ' Export slide
                    sImageName = sImagePath & "\" & sPrefix & "-" & Format$(.SlideIndex, "000") & "." & img_format
                    .Export sImageName, img_format, newWidth, newHeight
                    ' Add it to the temporary presentation
                    Set oSlideNew = oPresTmp.Slides.Add(oPresTmp.Slides.Count + 1, ppLayoutBlank)
                    Set oPic = oSlideNew.Shapes.AddPicture(FileName:=sImageName, _
                        LinkToFile:=msoFalse, _
                        SaveWithDocument:=msoTrue, _
                        Left:=0, _
                        Top:=0, _
                        Width:=-1, _
                        Height:=-1)
                        ' width/height of -1 tells PPT to import the image at its "natural" size
                End If
            End With
        Next oSlide
        
        With oPresTmp
            ' Export temp presentation to pdf
            Dim sPDFName As String
            sPDFName = sImagePath & ".pdf"
            .ExportAsFixedFormat sPDFName, ppFixedFormatTypePDF, ppFixedFormatIntentPrint, msoFalse, _
                ppPrintHandoutVerticalFirst, ppPrintOutputSlides, msoFalse
            
            ' Close temp presentation
            .Saved = True
            .Close
        End With
    
    Err_ImageSave:
        If Err <> 0 Then
            MsgBox Err.Description
        End If
    End Sub
    
    • 1

relate perguntas

  • Caixa de texto com colunas de larguras variadas

  • No MS PowerPoint: Existe alguma possibilidade de excluir todos os slides que estão ocultos?

  • Imprimindo em CMYK

  • Recorte e reorganize o PDF A3 digitalizado em duplex para o formato A4

  • A atualização do WebBrowser não atualiza o nível de zoom do PDF

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Como posso reduzir o consumo do processo `vmmem`?

    • 11 respostas
  • Marko Smith

    Baixar vídeo do Microsoft Stream

    • 4 respostas
  • Marko Smith

    O Google Chrome DevTools falhou ao analisar o SourceMap: chrome-extension

    • 6 respostas
  • Marko Smith

    O visualizador de fotos do Windows não pode ser executado porque não há memória suficiente?

    • 5 respostas
  • Marko Smith

    Como faço para ativar o WindowsXP agora que o suporte acabou?

    • 6 respostas
  • Marko Smith

    Área de trabalho remota congelando intermitentemente

    • 7 respostas
  • Marko Smith

    O que significa ter uma máscara de sub-rede /32?

    • 6 respostas
  • Marko Smith

    Ponteiro do mouse movendo-se nas teclas de seta pressionadas no Windows?

    • 1 respostas
  • Marko Smith

    O VirtualBox falha ao iniciar com VERR_NEM_VM_CREATE_FAILED

    • 8 respostas
  • Marko Smith

    Os aplicativos não aparecem nas configurações de privacidade da câmera e do microfone no MacBook

    • 5 respostas
  • Martin Hope
    CiaranWelsh Como posso reduzir o consumo do processo `vmmem`? 2020-06-10 02:06:58 +0800 CST
  • Martin Hope
    Jim Pesquisa do Windows 10 não está carregando, mostrando janela em branco 2020-02-06 03:28:26 +0800 CST
  • Martin Hope
    v15 Por que uma conexão de Internet gigabit/s via cabo (coaxial) não oferece velocidades simétricas como fibra? 2020-01-25 08:53:31 +0800 CST
  • Martin Hope
    fixer1234 O "HTTPS Everywhere" ainda é relevante? 2019-10-27 18:06:25 +0800 CST
  • Martin Hope
    andre_ss6 Área de trabalho remota congelando intermitentemente 2019-09-11 12:56:40 +0800 CST
  • Martin Hope
    Riley Carney Por que colocar um ponto após o URL remove as informações de login? 2019-08-06 10:59:24 +0800 CST
  • Martin Hope
    zdimension Ponteiro do mouse movendo-se nas teclas de seta pressionadas no Windows? 2019-08-04 06:39:57 +0800 CST
  • Martin Hope
    jonsca Todos os meus complementos do Firefox foram desativados repentinamente, como posso reativá-los? 2019-05-04 17:58:52 +0800 CST
  • Martin Hope
    MCK É possível criar um código QR usando texto? 2019-04-02 06:32:14 +0800 CST
  • Martin Hope
    SoniEx2 Altere o nome da ramificação padrão do git init 2019-04-01 06:16:56 +0800 CST

Hot tag

windows-10 linux windows microsoft-excel networking ubuntu worksheet-function bash command-line hard-drive

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve