質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

Q&A

0回答

1197閲覧

エクセルからグループ化した図形をパワーポイントに貼り付けたい

Minnku

総合スコア4

VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

0グッド

0クリップ

投稿2019/11/29 05:55

編集2019/11/29 06:06

エクセルで作成したグループ化させた図形(テキスト入力あり)を「元の書式を保持」したまま
パワーポイントのシートの位置や貼付大きさを指定した上で貼り付けがしたいです。

しかし実行すると以下のエラーメッセージが表示さえ、パワーポイントへの貼り付けが行えないです。
原因と対処方法を教えてほしいです。

発生している問題・エラーメッセージ

オブジェクトは、このプロパティまたはメソッドをサポートしていません。

該当のソースコード

VBA

1Public Name As Object 'オブジェクト名 2Public SldNmb As Integer 'スライド番号 3Public Top As Integer '上からの位置 4Public Left As Integer '左からの位置 5Public Width As Integer '横幅 6Public Odr As Integer '順番 7 8Property Get Self() As Class1 9 Set Self = Me '自己参照 10End Property 11 12Function CreateNew(NewName As Object, NewSldNmb As Integer, NewTop As Integer, _ 13 NewLeft As Integer, NewWidth As Integer, NewOdr As Integer) As Class1 14 With New Class1 15 Set .Name = NewName 'オブジェクト名 16 .SldNmb = NewSldNmb 'スライド番号 17 .Top = NewTop '上からの位置 18 .Left = NewLeft '左からの位置 19 .Width = NewWidth '横幅 20 .Odr = NewOdr '順番 21 Set CreateNew = .Self '作成したインスタンスを返す 22 End With 23End Function

VBA

1Sub オートシェイプ一斉貼り付け() 2 'コレクション生成 3 Dim Objs As Collection: Set Objs = New Collection 4 5 'シート名を変数へセット 6 Dim s1 As Worksheet: Set s1 = Sheets("シート1") 7 Dim s2 As Worksheet: Set s1 = Sheets("シート2") 8 9 '各要素をコレクションにセット 10 'オブジェクト名, スライド番号, 上からの位置, 左からの位置, 横幅, 順番(0→最前面 1→最背面) の順で 11 With New Class1 12 Objs.Add .CreateNew(s1.Shapes.Range(Array("Group 1")), 2, 50, 10, 600, 0) 13 Objs.Add .CreateNew(s1.Shapes.Range(Array("Group 4")), 2, 50, 10, 600, 0) 14 15 Objs.Add .CreateNew(s2.Shapes.Range(Array("Group 1")), 3, 50, 10, 600, 0) 16 Objs.Add .CreateNew(s2.Shapes.Range(Array("Group 4")), 3, 50, 10, 600, 0) 17 End With 18 19 'PPTの準備 20 On Error GoTo ERROR_HANDLER 21 Dim ppApp As Object: Set ppApp = CreateObject("PowerPoint.Application") 'PPTアプリ 22 Dim pp As Object: Set pp = ppApp.ActivePresentation 'PPTプレゼン 23 Dim ppSld As Object 'PPTスライド 24 25 Dim Obj As Class1 26 For Each Obj In Objs 'Objsコレクションをループ 27 Obj.Name.CopyPicture xlScreen, xlPicture '指定オブジェクトをクリップボードにコピー 28 Set ppSld = pp.Slides(Obj.SldNmb) 'PowerPointスライド指定 29 ppSld.Shapes.Paste '貼り付け 30 31 '位置・サイズを補正 32 With ppSld.Shapes(ppSld.Shapes.Count) '最終シェイプを指定 33 .LockAspectRatio = msoTrue '縦横比固定 34 .Top = Obj.Top '上からの位置 35 .Left = Obj.Left '左からの位置 36 .Width = Obj.Width '横幅 37 .ZOrder Obj.Odr '移動 38 End With 39 Next 40 41TERMINATE: 42 On Error GoTo 0 43 Set ppApp = Nothing 44 Set pp = Nothing 45 Set ppSld = Nothing 46 Exit Sub 47 48ERROR_HANDLER: 49 MsgBox Err.Description, vbCritical 50 Resume TERMINATE 51End Sub

補足事項

貼り付け先のパワーポイントは、指定されているスライドがすべて存在していて、既に開いているのが条件です。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問