ここから本文です

【Powerpointマクロ】ページの集計と集計したページ数を目次に反映したい。

fug********さん

2020/2/2222:38:08

【Powerpointマクロ】ページの集計と集計したページ数を目次に反映したい。

P1 表紙
P2 目次
P3~P5 資料1
P6~P8 資料2
P9~P11 資料3
の場合、資料1、2、3のそれぞれのページ数を集計して
目次に下記のようなページ数を入れていきたいです。
資料1…P3
資料2…P6
資料3…P9

Excelマクロだとif文を使用して
「テキストボックスに”資料1”があればカウントしていく」
みたいに作成すると思うのですが、
Powerpointのマクロは触ったことがなくて、想像がつかなかった為質問しました。

御回答よろしくお願いします。

閲覧数:
9
回答数:
1
お礼:
50枚

違反報告

ベストアンサーに選ばれた回答

プロフィール画像

カテゴリマスター

hot********さん

2020/2/2306:40:41

やりたい事はだいたいわかるのですが、具体的にタイトルはどこにどうあって、結果はどう表示するのでしょうか。
例えば3ページ目以降でテクストボックスの文字列が「資料1」「資料2」「資料3」のページを探して表示します。

Sub sample()
Dim titles(2) As String
titles(0) = "資料1"
titles(1) = "資料2"
titles(2) = "資料3"
Dim pg() As Integer
Dim p As Integer
Dim shp As Shape
Dim i As Integer
ReDim pg(UBound(titles)) 'ページ用配列
For p = 3 To ActivePresentation.Slides.Count '3ページから最終ページまで
For Each shp In ActivePresentation.Slides(p).Shapes '注目ページのシェープを順に
If shp.Type = msoTextBox Then 'テキストボックスなら
For i = 0 To UBound(titles) 'タイトルを順に
If shp.TextEffect.Text = titles(i) Then 'テキストボックスの文字列がタイトルと同じなら
pg(i) = p 'ページを設定
Exit For 'このテキストボックスのチェック終了
End If
Next
End If
Next
Next
'結果表示
Dim s As String
For i = 0 To UBound(titles)
s = s & titles(i) & " P." & pg(i) & vbCrLf
Next
MsgBox s
End Sub

やりたい事はだいたいわかるのですが、具体的にタイトルはどこにどうあって、結果はどう表示するのでしょうか。...

質問した人からのコメント

2020/2/29 20:28:31

御回答ありがとうございました。

タイトル部分は横書きテキストボックスで作成されていて、
目次に
資料1…P3
資料2...P6
のように表示させるつもりでした。

タイトル部分を配列にできたらして、資料1のページが増減したら、
目次に表示させるページも変更するような作りにできたらと思っています。

みんなで作る知恵袋 悩みや疑問、なんでも気軽にきいちゃおう!

Q&Aをキーワードで検索:

Yahoo! JAPANは、回答に記載された内容の信ぴょう性、正確性を保証しておりません。
お客様自身の責任と判断で、ご利用ください。
本文はここまでです このページの先頭へ

「追加する」ボタンを押してください。

閉じる

※知恵コレクションに追加された質問は選択されたID/ニックネームのMy知恵袋で確認できます。

不適切な投稿でないことを報告しました。

閉じる