
Powerpointファイルを開いて、
ホーム-配置-オブジェクトの選択と表示 でスライドのShapeオブジェクト一覧が表示されます。(添付画像参照)。このスライドから黄色い蛍光ペンで塗った、”コンテンツプレースホルダー2”の
Shapeオブジェクトを削除しようとして、下記のPowerpointVBAを実行しましたが、何も削除されません。コードをどう直せば動きますか? わかる方教えてください。
--<start of code>----
Sub delete()
Dim s As Shape 'sはshapeオブジェクトを入れる変数
Dim c As Collection 'cはコレクション
Dim start_slide As Integer 'start_slideはスライド番号1を入れる定数
Dim i As Integer 'iはスライド番号を入れる変数
start_slide = 1
For i = start_slide To ActivePresentation.Slides.Count
'If i = 254 Then
' GoTo continue
'End If
Set c = New Collection
For Each s In ActivePresentation.Slides(i).Shapes '変数sにアクティブスライド番号のすべてのshapeオブジェクトを入れる。
c.Add s
Next
For Each s In c
If InStr(s.Title, "コンテンツ") > 0 Then s.delete '★ここが重要!
Next
'continue:
Next
'MsgBox "the process is finished."
End Sub
--<end of code>----

No.2ベストアンサー
- 回答日時:
>If InStr(s.Title, "コンテンツ") > 0 Then s.delete '★ここが重要!
の「Title」を「Name」にするとどうでしょうか。
If InStr(s.Name, "コンテンツ") > 0 Then s.delete '★ここが重要!
If InStr(s.Name, "コンテンツ") > 0 Then s.delete '★ここが重要!
でうまく行きました。ありがとうございます。
No.1
- 回答日時:
>”コンテンツプレースホルダー2”のShapeオブジェクトを削除しようとして
>For Each s In ActivePresentation.Slides(i).Shapes '変数sにアクティブスライド番号のすべてのshapeオブジェクトを入れる。
>If InStr(s.Title, "コンテンツ") > 0 Then s.delete '★ここが重要!
全角表示を取得する方法は不明ですけど、とりあえずプレスホルダー名を取得しその結果としては。
Dim sl As Slide
Dim sh As Shape
For Each sl In ActivePresentation.Slides
For Each sh In sl.Shapes.Placeholders
Debug.Print sh.Name, ": " & InStr(sh.Name, "Placeholder 2")
Next
Next
結果:
Title 1 : 0
Subtitle 2 : 0
Title 1 : 0
Content Placeholder 2 : 9
Content Placeholder 3 : 0
みたいになりますね。
多分コントロール名だと思いますけど、半角文字が使われているようです。
と、ほぼPowerPointを使わないのでその先は良くわかりません。
WordVBAやっている方ならいけるんじゃないのかな?
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) 【VBA】写真の貼り付けコードがうまく機能しません。 5 2022/09/01 18:43
- Visual Basic(VBA) VBA Userformで一部別シートに転記がしたいのですが 2 2023/05/24 13:08
- Visual Basic(VBA) VBA This Workbookモジュールを別ファイルにコピーする方法 1 2022/09/14 01:51
- Visual Basic(VBA) VBAが止まります。 2 2022/09/02 14:02
- Excel(エクセル) フォルダ内のワードファイルをPDFに一括変換するVBA 3 2023/06/09 16:51
- Visual Basic(VBA) Excel VBAの解読について質問があります。 概要は、マクロでチェックボックスにチェックすると日 1 2023/02/10 07:50
- Visual Basic(VBA) ExcelVBAに関する質問 3 2023/02/17 10:47
- Visual Basic(VBA) ①ExcelVBAでカレンダーを作り、別のユザーフォームで日付を入力したいのですがエラーになります。 1 2023/02/17 18:39
- Visual Basic(VBA) 数字が「0」の列を削除するため、下記のコードを実行しましたが、コンパイルエラーSubまたはFunct 3 2022/12/04 00:00
- Visual Basic(VBA) EXCEL VBAにて動的にCheckBOXを複数作成し、同BOXにイベントを追加したい 1 2023/03/16 07:05
このQ&Aを見た人はこんなQ&Aも見ています
-
パワーポイントのVBAでテキストボックスに値を変更させたいです
Visual Basic(VBA)
-
なぜマクロの記録がなくなってしまったのでしょうか?
Excel(エクセル)
-
ExcelVBAにて既に開かれているPowerpointをアクティブにするには?
Excel(エクセル)
-
-
4
PowerpointVBAで複数のShapeオブジェクトを選択削除したい。
Visual Basic(VBA)
-
5
VBAでループ内で使う変数名を可変にできないか。
Visual Basic(VBA)
-
6
【VB.NET】 パワポ操作を非表示で
Visual Basic(VBA)
-
7
VBAで既存のパワポのファイルを開くには?
Access(アクセス)
-
8
【PowerPoint VBAの高速化】
その他(プログラミング・Web制作)
-
9
PowerPoint の VBA
Visual Basic(VBA)
関連するカテゴリからQ&Aを探す
今、見られている記事はコレ!
-
弁護士が語る「合法と違法を分けるオンラインカジノのシンプルな線引き」
「お金を賭けたら違法です」ーーこう答えたのは富士見坂法律事務所の井上義之弁護士。オンラインカジノが違法となるかどうかの基準は、このように非常にシンプルである。しかし2025年にはいって、違法賭博事件が相次...
-
釣りと密漁の違いは?知らなかったでは済まされない?事前にできることは?
知らなかったでは済まされないのが法律の世界であるが、全てを知ってから何かをするには少々手間がかかるし、最悪始めることすらできずに終わってしまうこともあり得る。教えてgooでも「釣りと密漁の境目はどこです...
-
カスハラとクレームの違いは?カスハラの法的責任は?企業がとるべき対応は?
東京都が、客からの迷惑行為などを称した「カスタマーハラスメント」、いわゆる「カスハラ」の防止を目的とした条例を、全国で初めて成立させた。条例に罰則はなく、2025年4月1日から施行される。 この動きは自治体...
-
なぜ批判コメントをするの?その心理と向き合い方をカウンセラーにきいた!
今や生活に必要不可欠となったインターネット。手軽に情報を得られるだけでなく、ネットを介したコミュニケーションも一般的となった。それと同時に顕在化しているのが、他者に対する辛らつな意見だ。ネットニュース...
-
大麻の使用罪がなかった理由や法改正での変更点、他国との違いを弁護士が解説
ドイツで2024年4月に大麻が合法化され、その2ヶ月後にサッカーEURO2024が行われた。その際、ドイツ警察は大会運営における治安維持の一つの方針として「アルコールを飲んでいるグループと、大麻を吸っているグループ...
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
文字列で小数点以下の0を削除し...
-
VBA エンターキーでイベントに...
-
Accessのフォーム上にエクセル...
-
アクセスVBAのMe!と[ ]
-
EXCEL VBA ユーザフォームで複...
-
C++Builder 6 でドラッグ&ドロ...
-
pythonのreモジュールについて
-
VBAでオブジェクトを小数点で位...
-
openGLにおいて描画した物体に...
-
VBでExcelの表形式の様なデザイ...
-
SelectObjectの戻り値
-
PowerpointVBAで指定のShapeオ...
-
更新処理
-
コードでオブジェクトを最前面に
-
構造体の静的な初期化
-
フリーズしてしまいます。
-
ACCESSマクロ、Me![氏名] その...
-
エクセルのデータをwebフォーム...
-
アクセスの1つのファイルにはク...
-
ChexBox1等の「1」を変数にで...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
VBA エンターキーでイベントに...
-
アクセスVBAのMe!と[ ]
-
エクセルVBAでセル番地を指定し...
-
Excel VBAでマウスの左クリック...
-
Accessのフォーム上にエクセル...
-
日本語の文字化けを直す方法
-
文字列で小数点以下の0を削除し...
-
コードでオブジェクトを最前面に
-
Excel2007 でのチェックボック...
-
ExcelのシートをAccessで表示し...
-
【エクセルのマクロ】クリップ...
-
LoadImage関数について(VC++)
-
【エクセル】複数のTextBoxに共...
-
[C#] DataGridViewの項目名
-
現在アクティブになっているオ...
-
Webbrowserで完全にHPを表示さ...
-
サブルーチンにオブジェクト名...
-
ユーザーフォームのインポート...
-
ビデオキャプチャについて
-
代入しているのになぜnullのま...
おすすめ情報