🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
VBA

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

マクロ

定義された処理手続きに応じて、どのような一連の処理を行うのかを特定させるルールをマクロと呼びます。

検索

検索は、あるデータの集まりの中から 目的のデータを見つけ出すことです。

Q&A

解決済

2回答

5931閲覧

VBA 図形内文字列検索

kty_kk

総合スコア4

VBA

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

マクロ

定義された処理手続きに応じて、どのような一連の処理を行うのかを特定させるルールをマクロと呼びます。

検索

検索は、あるデータの集まりの中から 目的のデータを見つけ出すことです。

0グッド

1クリップ

投稿2021/03/09 08:03

編集2021/03/09 08:08

前提・実現したいこと

VBAマクロにおいて
エクセルファイルにおける、図形内の文字列検索メソッドを作成しています。
このコード自体はネットから拾ってきたものにはなります。
どこをどのように修正すべきかご教授願います。

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

text = parentShape.DrawingObject.Characters.textにおいて、 実行時エラー '438' オブジェクトは、このプロパティまたはメソッドをサポートしていません。 とでる。

該当のソースコード

VBA

1Option Explicit 2 3Sub SearchInAutoShape() 4 ' 入力ファイル 5 Dim inputfile As String 6 inputfile = "C:\work\sample.xlsx" 7 8 ' 検索キーワード 9 Dim keyword As String 10 keyword = "修正" 11 12 ' ファイルオープン 13 Application.ScreenUpdating = False 14 Dim inputBook As Workbook 15 Set inputBook = Workbooks.Open(inputfile, ReadOnly:=True) 16 17 ' シート数分繰り返し 18 Dim i As Long 19 For i = 1 To inputBook.Worksheets.Count 20 21 ' シートに貼り付けられているオートシェイプ分繰り返す 22 Dim parentShape As Shape 23 For Each parentShape In inputBook.Worksheets(i).Shapes 24 Dim text As String 25 26 ' オートシェイプがグループ化されている場合、 27 ' グループ化されているオートシェイプのテキストをチェック 28 If parentShape.Type = msoGroup Then 29 Dim groupedShape As Shape 30 For Each groupedShape In parentShape.GroupItems 31 text = groupedShape.TextFrame.Characters.text 32 If InStr(text, keyword) > 0 Then 33 Debug.Print ("sheet : " + inputBook.Worksheets(i).Name) 34 Debug.Print ("text : " + text) 35 End If 36 Next groupedShape 37 38 ' オートシェイプがグループ化されていない場合 39 ' そのオートシェイプのテキストをチェック 40 Else 41 text = parentShape.DrawingObject.Characters.text 42 If InStr(text, keyword) > 0 Then 43 Debug.Print ("sheet : " + inputBook.Worksheets(i).Name) 44 Debug.Print ("text : " + text) 45 End If 46 End If 47 Next parentShape 48 Next i 49 50 ' ファイルクローズ 51 inputBook.Close SaveChanges:=True 52 Set inputBook = Nothing 53 Application.ScreenUpdating = True 54 55End Sub 56

試したこと

デバックをし、1行ずつ実行はしてみても、同様のエラーが出てしまい、進むことが出来ません。
また、エラー内容を検索しても、誤字脱字等が原因、と検索結果で出てきて
一通り確認はしたのですが誤字脱字は見つかりませんでした。

補足情報(FW/ツールのバージョンなど)

VBAツールを学び始めたものです。
基礎知識は学び、まずはトレースから初めて実行しております。
お手数をおかけしますがお願いいたします。
EXCEL2010,2016 の両環境で実施しました。
※キーワードとパスについては実際の私の環境で適したものを
指定して実行しています。

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

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

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

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

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

guest

回答2

0

私も、昨年ネットで調べたことがありましたので、URL記載します
「インストラクターのネタ帳」様のです
https://www.relief.jp/docs/excel-vba-shape-hastext.html
イメージ説明

このままのコードだと、下図のようなエラー表示
イメージ説明
グループ化解除すると下図のように文字 取得できました
イメージ説明
参考までにコード記載します。

VBA

1コード 2```Sub Shape内の文字列を取得する_TextFrame2() 3 Dim shp As Shape 4 'シート内の図形全てクリックした(グループ化解除)状態 5 ActiveSheet.Shapes.SelectAll 6 7 For Each shp In ActiveSheet.Shapes 8 If shp.TextFrame2.HasText Then 9 MsgBox shp.TextFrame2.TextRange.Text 10 End If 11 Next shp 12 Range("A1").Select ' 再グループ化??? 13 14End Sub

投稿2021/03/10 11:11

syousuke.33

総合スコア312

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

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

0

ベストアンサー

確か、直線矢印とかがあるとそうなるはず。
textを取得する前に Debug.Print parentShape.Name, parentShape.Type とか入れて確認してみては?
丁寧にやるなら、Select Case parentShape.Type で分岐。
乱暴にやるなら、On Error Resume Next で突き進む手もある。

VBA

1Select Case parentShape.Type 2Case msoGroup '6 3 ' 4 ' 5 ' 6Case msoAutoShape '1 7 If parentShape.TextFrame2.HasText Then 8 text = parentShape.DrawingObject.Characters.text 9 End If 10 11Case msoTextBox '17 12 ' 13 ' 14Case msoComment '4 15 ' 16 ' 17Case msoLine '9 18 ' 19 ' 20 21Case Else 22 23End Select

投稿2021/03/09 12:51

編集2021/03/10 05:51
jinoji

総合スコア4592

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

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

kty_kk

2021/03/10 05:21

仰る通り、矢印があるExcelファイルを対象に行うとこのエラーが起きました。 Debug.Print parentShape.Name,parentShape.Type でをtext取得する直前に挿入して実行してみたところ、エラーを確認し、 Typeプロパティで取得した定数が"1"で、原因がわかりませんでした。 どのように解消できますでしょうか。
jinoji

2021/03/10 06:32 編集

回答に追記しました。 基本は ParentShape.TextFrame2.HasText で判断したいですが、 Typeによってはそれ自体がエラーになるものがあるみたいなので、 パターンによって処理を書き分ける感じで考えてみました。 すみませんが私もすべてのパターンを押さえているわけではないので ご自身の環境でエラーが出たらパターンを増やす感じで徐々に対応する形で・・・
kty_kk

2021/03/18 06:55

ご返信遅くなってしまい申し訳ございません。解決することが出来ました。 ありがとうございます!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問