[爆卦]excel表格貼到powerpoint是什麼?優點缺點精華區懶人包

為什麼這篇excel表格貼到powerpoint鄉民發文收入到精華區:因為在excel表格貼到powerpoint這個討論話題中,有許多相關的文章在討論,這篇最有參考價值!作者foolkids (翼をください)看板Office標題[算表] 透由VBA複製Excel儲存格到...


軟體:MS Office

版本:2010

一般在Excel直接選擇一特定範圍(例如A1:C12)複製並於PPT貼上時,會產生一個類似表格的物件,
可快速進行簡易編輯

但是透由巨集貼上時,卻會變成一個內嵌的Excel檔案,如果要編輯的時候就會切換成一個類似Excel的編輯器

有辦法透由巨集貼上一個簡易的表格物件嗎?


目前的測試巨集內容如下:

Option Explicit

Sub ExcelRangeToPowerPoint()
'PURPOSE: Copy/Paste An Excel Range Into a New PowerPoint Presentation
'SOURCE: www.TheSpreadsheetGuru.com

Dim rng As Range
Dim PowerPointApp As Object, myPresentation As Object, mySlide As Object, myShape As Object

'Copy Range from Excel
Set rng = ThisWorkbook.ActiveSheet.Range("A1:C12")

'Create an Instance of PowerPoint
On Error Resume Next

'Is PowerPoint already opened?
Set PowerPointApp = GetObject(class:="PowerPoint.Application")

'Clear the error between errors
Err.Clear

'If PowerPoint is not already open then open PowerPoint
If PowerPointApp Is Nothing Then Set PowerPointApp = CreateObject(class:="PowerPoint.Application")

'Handle if the PowerPoint Application is not found
If Err.Number = 429 Then
MsgBox "PowerPoint could not be found, aborting."
Exit Sub
End If

On Error GoTo 0

'Optimize Code
Application.ScreenUpdating = False

'Create a New Presentation
Set myPresentation = PowerPointApp.Presentations.Add

'Add a slide to the Presentation
Set mySlide = myPresentation.Slides.Add(1, 11) '11 = ppLayoutTitleOnly

'Copy Excel Range
rng.Copy

'Paste to PowerPoint and position
mySlide.Shapes.PasteSpecial DataType:=10 ' 2 = ppPasteEnhancedMetafile
'10 = ppPasteOLEObject
Set myShape = mySlide.Shapes(mySlide.Shapes.Count)

'Set position:
myShape.Left = 66
myShape.Top = 152

'Make PowerPoint Visible and Active
PowerPointApp.Visible = True
PowerPointApp.Activate

'Clear The Clipboard
Application.CutCopyMode = False

End Sub

--
┌─────────────────────────────┐
就這樣,終於到了啟程的日子。
和來機場送行的朋友們說著玩笑話,其實內心恍恍惚惚像在作夢。
也似乎是因為,為了走到「出發」這一步,耗盡了全部心力。
└─────────────────石田裕輔《不去會死!》─┘

--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 223.137.40.168
※ 文章網址: https://www.ptt.cc/bbs/Office/M.1499154145.A.5B2.html
soyoso: datatype改為0,看是否是原po要的 07/04 15:59
foolkids: S大,0會卡住,沒辦法續行耶 07/04 16:18
soyoso: 那將myslide.shapes.pastespecial這行改為 07/04 16:43
soyoso: powerpointapp.commandbars.executemso ("PasteSourceForm 07/04 16:46
soyoso: atting") 07/04 16:46
foolkids: 程序呼叫或引述不正確,好像參數不能這樣加上去,因為括 07/04 16:51
foolkids: 號前面出現了空格 07/04 16:51
foolkids: 測試複製一個slide可行,但是複製Range還是不行 07/04 17:00
soyoso: https://youtu.be/XcsfWAi0qiE 回文,executemso的測試 07/04 17:38
foolkids: … 奇怪,為何我會卡住… 我再試試看,謝謝S大! 07/04 18:13
foolkids: 發現要加Application.Wait那行才行… 總算成功了, 07/04 18:19
foolkids: 可是不是很穩,最穩的方式是停在PowerPointApp那行, 07/04 18:31
foolkids: 手動繼續執行… 這是什麼問題? 07/04 18:31
foolkids: 後來透由Shapes.count進行卡控迴圈,終於解決了… 07/04 19:27
foolkids: 結果有了新的問題... 這樣複製過來的Shape無法使用 07/04 21:10
foolkids: Shape.ScaleWidth或是Shape.ScaleHeight的方法,有解嗎? 07/04 21:12
soyoso: 以shape.width和height來調整試試 07/05 07:10
foolkids: 好喔,應該可行,只是又要大改,哈哈 07/05 07:58
foolkids: 欸… Shape.width = Shape.wIdth * ScaleRate 就好了… 07/05 08:33
※ 編輯: foolkids (223.140.240.10), 07/05/2017 08:37:28

你可能也想看看

搜尋相關網站