エクセルから表をパワーポイントへ貼り付けたときの、位置調整がうまくいきません。宜しくお願いします。
--------------------
sub test1()
Dim pptApp As Object
Dim pptPre As Object
Dim tempFileName As String
Dim macrofile As String 'エクセルの貼り付け元のファイル名
Dim sht As String 'エクセルの貼り付け元のシート名
Dim page As Integer 'パワーポイントへの貼り付けたいページ
Dim picPos_yoko As Long 'パワーポイントへの貼り付け横位置
Dim picPos_tate As Long 'パワーポイントへの貼り付け縦位置
macrofile = "sample001.xls"
sht = "sheet1"
tempFileName = ThisWorkbook.Path & Application.PathSeparator _
& macrofile
Set pptApp = CreateObject("powerPoint.Application")
With pptApp
.Visible = True
Set pptPre = .Presentations.Open(tempFileName)
End With
Workbooks(macrofile).Worksheets(sht).Activate
Range("A1").CurrentRegion.Copy '表のコピー
With pptPre.Slides(page)
.Shapes.Paste.Name = "hyou1"
With .Shapes("hyou1")
.Top = picPos_yoko
.Left = picPos_tate
End With
End With
End Sub
------------------------
.Shapes.Paste.Name = "pic1"
↑この行で名前をつけたかったがうまく名前がついていない。
貼り付けた表の名前をパワーポイントのマクロの記録で確認したところ "Group 288"と名前がついていた
With .Shapes("hyou1")
↑当然この行で"hyou1"は見つからないというエラーが出てしまう。
表をエクセルからコピーして、パワーポイントへ位置を指定して張り付けるかもしくは貼り付けた後に移動ができるかを実現したい。
何かいい方法はありませんか?パワーポイントへエクセルからグラフを貼り付けた場合はうまくいきました。
また。パワーポイントの表の名前のつけ方には規則性があるのでしょうか。規則性があれば、それに則ってコードをかけるのですが・・・。
No.3ベストアンサー
- 回答日時:
書き忘れました。
下のコードにして、名前が変更されていることも確認してください。
オブジェクト名: hyou1 になると思います。
With pptPre.Slides(page).Shapes
.Paste
With .Item(.Count)
.Name = "hyou1"
.Top = picPos_tate
.Left = picPos_yoko
MsgBox "オブジェクト名: " & .Name
End With
End With
No.2
- 回答日時:
Pasteメソッドが返すShapeRangeオブジェクトはあまり
あてにならないので、すぐには使わず、
いったんSlide.Shapesプロパティから貼り付けたオブジェクトを取得、
名前を設定としてみてください。もしかしたらうまくいくかもしれません。
With pptPre.Slides(page).Shapes
.Paste
With .Item(.Count)
.Name = "hyou1"
.Top = picPos_tate
.Left = picPos_yoko
End With
End With
※バージョンが違うとだめな場合があります。
例えばPPT2007の場合は
pptApp.ActiveWindow.View.Paste
With pptPre.Slides(page).Shapes
With .Item(.Count)
.Name = "hyou1"
.Top = picPos_tate
.Left = picPos_yoko
End With
End With
No.1
- 回答日時:
1、位置に関して・・・単に縦横を逆に設定しているだけでしょう。
.Top = picPos_yoko
.Left = picPos_tate
2、「名前」は変更できないみたいです。
表は非常にたくさんのオブジェクトがグループ化されたものとして
扱われています。
どうしても名前を付け替えるなら
図として張り付ければ可能でしょう。
貼り付ける場合は必ず最後のshapeになるのでこのようにcountを使うことで名前を取得できます。
.Shapes(.Shapes.Count).Name
1.これは記述を間違って逆にしてしまいました。誤解を与えてすみませんでした。m__m
2.なるほど図として貼り付けたところうまくいきました。ありがとうございます。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) Excel VBA メール作成について 本文の中にExcel でコピーした図を上下に2つ 貼り付けを 2 2023/06/14 01:48
- Excel(エクセル) 【マクロ】スクショ印刷がうまく動かない件 5 2022/12/06 17:37
- Visual Basic(VBA) 【VBA】写真の貼り付けコードがうまく機能しません。 5 2022/09/01 18:43
- Visual Basic(VBA) 【ご教示ください】VBAの記述方法がわかりません。 2 2022/08/12 21:28
- Visual Basic(VBA) 【VBA】写真の縦横比を変えずに貼り付ける 5 2023/06/13 11:42
- その他(Microsoft Office) マクロVBAについて 1 2022/09/06 18:12
- Visual Basic(VBA) 【前回の続きです、ご教示ください】VBAの記述方法がわかりません。 2 2022/08/16 16:44
- Visual Basic(VBA) excel vbaでvlooupの変数がわかりません。 7 2022/05/30 09:35
- Visual Basic(VBA) QRコード作成マクロについて 3 2022/11/26 16:55
- Visual Basic(VBA) 【前回の続き続きです、ご教示ください】VBAの記述方法がわかりません。 2 2022/08/24 20:49
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・【大喜利】【投稿~11/12】 急に朝起こしてきた母親に言われた一言とは?
- ・好きな和訳タイトルを教えてください
- ・うちのカレーにはこれが入ってる!って食材ありますか?
- ・好きな「お肉」は?
- ・あなたは何にトキメキますか?
- ・おすすめのモーニング・朝食メニューを教えて!
- ・「覚え間違い」を教えてください!
- ・とっておきの手土産を教えて
- ・「平成」を感じるもの
- ・秘密基地、どこに作った?
- ・【お題】NEW演歌
- ・カンパ〜イ!←最初の1杯目、なに頼む?
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・チョコミントアイス
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・あなたの習慣について教えてください!!
- ・ハマっている「お菓子」を教えて!
- ・高校三年生の合唱祭で何を歌いましたか?
- ・【大喜利】【投稿~11/1】 存在しそうで存在しないモノマネ芸人の名前を教えてください
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・家の中でのこだわりスペースはどこですか?
- ・つい集めてしまうものはなんですか?
- ・自分のセンスや笑いの好みに影響を受けた作品を教えて
- ・【お題】引っかけ問題(締め切り10月27日(日)23時)
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・架空の映画のネタバレレビュー
- ・「お昼の放送」の思い出
- ・昨日見た夢を教えて下さい
- ・ちょっと先の未来クイズ第4問
- ・【大喜利】【投稿~10/21(月)】買ったばかりの自転車を分解してひと言
- ・メモのコツを教えてください!
- ・CDの保有枚数を教えてください
- ・ホテルを選ぶとき、これだけは譲れない条件TOP3は?
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・【コナン30周年】嘘でしょ!?と思った○○周年を教えて【ハルヒ20周年】
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
worksheetFunctionクラスのVloo...
-
エクセルのVBAの標準モジュール...
-
「Columns("A:C")」の列文字を...
-
テキストボックス中の文字列の...
-
Excelでフィルタをかけると警告...
-
実行時エラー 3265「要求された...
-
Excel VBAでWordの複数ファイル...
-
VBからPDFファイル自動生成...
-
InternetExplorer.Application...
-
EXCEL VBA オートシェイプナン...
-
vbaからIEを操作するための記載...
-
エクセルVBAでcode128のバー...
-
VBScriptからDLL参照設定したい
-
ExcelのVBAについて(グラフ操作)
-
[C#]static void 関数内でthis
-
データバインドされたDatagridv...
-
VBAで既に開いている別アプリケ...
-
VBAで作成するメール(開封確認...
-
上下の位置揃えについて
-
[VBA]CDOメッセージ送信エラー
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
worksheetFunctionクラスのVloo...
-
「Columns("A:C")」の列文字を...
-
Excelでフィルタをかけると警告...
-
エクセルのVBAの標準モジュール...
-
実行時エラー 3265「要求された...
-
VBAで既に開いている別アプリケ...
-
VBAからPDFファイルにパスワー...
-
PowerPointVBAでスライドマスタ...
-
EXCEL VBA オートシェイプナン...
-
オブジェクトが見つかりません
-
テキストボックス中の文字列の...
-
VBAで Set wb = Sheets(1).Cop...
-
エクセルマクロエラー「'Cells'...
-
ExcelVBAでのNZ関数について
-
上下の位置揃えについて
-
UserForm1.Showでエラーになり...
-
AccessVBAで「dim dbs as datab...
-
findメソッドの変数について
-
VBScriptでファイルの日時順(降...
-
Excel VBAでWordの複数ファイル...
おすすめ情報