
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も見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
アクセス全くの初心者です。A...
-
[Q:VBA] 現在のオブジェクトの...
-
Webbrowserで完全にHPを表示さ...
-
VBA エンターキーでイベントに...
-
演算子is... 初学者 Python 3
-
現在アクティブになっているオ...
-
アクセスVBAのMe!と[ ]
-
更新処理
-
エクセルVBAで、MsgBox やInput...
-
アプリケーションのインターフ...
-
お家デートをしててハグを長い...
-
「PC Helpsoft Driver Updated...
-
TextBoxの入力・表示の判別方法
-
ACCESS2003でカウンタとボタン...
-
SQL EXCEL VBA 接続
-
AS3でランダムな画像入れ替わり...
-
CMD.Executeの結果をメッセージ...
-
Googleフォーム・複数人の申し...
-
Excelシート上のマクロを登録し...
-
アメブロで、スクリプトエラー...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
VBA エンターキーでイベントに...
-
アクセスVBAのMe!と[ ]
-
エクセルVBAでセル番地を指定し...
-
Excel VBAでマウスの左クリック...
-
Accessのフォーム上にエクセル...
-
日本語の文字化けを直す方法
-
文字列で小数点以下の0を削除し...
-
コードでオブジェクトを最前面に
-
Excel2007 でのチェックボック...
-
ExcelのシートをAccessで表示し...
-
【エクセルのマクロ】クリップ...
-
LoadImage関数について(VC++)
-
【エクセル】複数のTextBoxに共...
-
[C#] DataGridViewの項目名
-
現在アクティブになっているオ...
-
Webbrowserで完全にHPを表示さ...
-
サブルーチンにオブジェクト名...
-
ユーザーフォームのインポート...
-
ビデオキャプチャについて
-
代入しているのになぜnullのま...
おすすめ情報