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

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

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

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

Q&A

解決済

1回答

2570閲覧

VBA 特定の名前の図の数をカウントしたい

Taro0827

総合スコア16

VBA

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

0グッド

0クリップ

投稿2023/06/19 08:17

実現したいこと

図に名前をつけ、その名前の数を数えたい

前提

ActiveSheet.Shapes.Count
こちらで、図の数は数えられますが、名前指定した図の数を数えるにはどのようにプログラム書けばいいでしょうか?
Shape("図形の名前")と書けば、カウントされるかと思いきや、エラー出てしまい、カウントできませんでした。。。

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

なし

該当のソースコード

Sub Count_Shapes()

Dim numShape As Integer numShape = ActiveSheet.Shapes.Count '←このShape("図形の名前")で書けば、カウントしてくれると思っていましたが。。。 Range("F1") = numShape

End Sub

試したこと

図の名前を取得→その取得した図の数を数えるという流れで書けばいいのかどうか?ここの場所でつまずいているので、
ご教授頂きたいです。

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

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

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

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

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

hatena19

2023/06/19 08:30

「特定の名前」とのことですが、同じ名前の図形は一つしかないはずですよね。 「特定の文字列」を含む図形の数をカウントしたいということならわかりますが。
Taro0827

2023/06/19 08:36

説明不足で申し訳ありません。 特定の文字列」を含む図形の数をカウントしたいです。 例)"図123"という図がSheet1にいくつあるか? ということになります。
guest

回答1

0

ベストアンサー

もし、「特定の文字列」を含む図形の数をカウントしたいということなら、ループで名前を部分一致でチェックすればいいでしょう。

vba

1Sub Count_Shapes() 2 3 Dim numShape As Long 4 Dim shp As Shape 5 6 For Each shp In ActiveSheet.Shapes 7 If shp.Name Like "*特定の文字列*" Then 8 numShape = numShape + 1 9 End If 10 Next 11 12 Range("F1") = numShape 13 14End Sub

投稿2023/06/19 08:35

hatena19

総合スコア34347

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

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

Taro0827

2023/06/19 09:03

ありがとうございます。 質問なのですが、"numShape = numShape + 1" こちらは数をカウントする際に必要なの?だと思いますが、+1はなぜ必要なのでしょうか?
hatena19

2023/06/19 09:50

なければ初期値0のままです。 +1で1加算されます。 デバッグでステップ実行して動作を確認する方法を検索してみて、実際に確認してみてください。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.31%

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

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

質問する

関連した質問