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

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

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

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

Word

Microsoft WordはMicrosoftが開発した業務用の文書生成用のソフトウェアです。

Q&A

解決済

1回答

231閲覧

Word VBAにてテキスト取得が上手くできない

Usushio166

総合スコア1

VBA

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

Word

Microsoft WordはMicrosoftが開発した業務用の文書生成用のソフトウェアです。

0グッド

0クリップ

投稿2024/07/04 01:31

実現したいこと

例として以下のようなWordファイルをHTMLファイルに出力
イメージ説明

結果ソースイメージ

<h1>見出し1</h1> <h2>見出し2</h2> <p>サンプル<u>下線</u>サンプル</p> <p>サンプル<b>マーク</b>サンプル</p> <h1>見出し1</h1>

発生している問題・分からないこと

該当ソースコードの「under = .range.Text」等の .range.Text が取得できない。

また、何度かコードを修正する中で、文書内では見出し1テキストや見出し2テキストの位置はバラバラだが、出力すると一箇所に固まる(その場でループされている?)

エラーメッセージ

error

1コンパイルエラー:メソッドまたはデータメンバーが見つかりません

該当のソースコード

Sub ExportToHTML() ' 出力ファイル名を指定 Dim outputFileName As String outputFileName = "output.html" ' 出力ファイルを作成 Dim outputDoc As Object Set outputDoc = CreateObject("htmlfile") ' ヘッダーを出力 outputDoc.Write "<!DOCTYPE html>" outputDoc.Write "<html>" outputDoc.Write "<head>" outputDoc.Write "<meta charset='UTF-8'>" outputDoc.Write "<title>Document</title>" outputDoc.Write "</head>" outputDoc.Write "<body>" ' 変換元の Word 文書を開く Dim sourceDoc As Document Set sourceDoc = ActiveDocument ' <h1>タグを付与する With sourceDoc.Content.Find .ClearFormatting .Style = "見出し 1" .Execute While .Found Dim headOne As String headOne = .Parent.Text outputDoc.Write "<h1>" & headOne & "</h1>" .Execute ' 次の見出しを検索 Wend End With ' <h2>タグを付与する With sourceDoc.Content.Find .ClearFormatting .Style = "見出し 2" .Execute While .Found Dim headTwo As String headTwo = .Parent.Text outputDoc.Write "<h2>" & headTwo & "</h2>" .Execute ' 次の見出しを検索 Wend End With ' <p>タグを付与する Dim range As range For Each range In sourceDoc.StoryRanges With range.Find .ClearFormatting .Style = "標準" .Execute While .Found outputDoc.Write "<p>" ' 下線が引かれているテキストに<u>タグを付与する If range.Font.Underline = wdUnderlineSingle Then Dim under As String under = .range.Text outputDoc.Write "<u>" & under & "</u>" ' range.InsertBefore "<span class=""under"">" ' range.InsertAfter "</span>" ' 蛍光ペンがついているテキストに<b>タグを付与する ElseIf range.HighlightColorIndex <> wdNoHighlight Then Dim mark As String mark = .range.Text outputDoc.Write "<b>" & mark & "</b>" ' range.InsertBefore "<span class=""mark"">" ' range.InsertAfter "</span>" ' その他のテキストに<p>タグを付与する Else Dim nomal As String nomal = .range.Text outputDoc.Write nomal ' range.InsertBefore "<p>" ' range.InsertAfter "</p>" End If .Execute outputDoc.Write "</p>" Wend End With Next range ' フッターを出力 outputDoc.Write "</body>" outputDoc.Write "</html>" ' ファイルを保存 Dim fs As Object Set fs = CreateObject("Scripting.FileSystemObject") Dim f As Object Set f = fs.CreateTextFile(outputFileName, True) f.Write outputDoc.body.innerHTML f.Close End Sub

試したこと・調べたこと

  • teratailやGoogle等で検索した
  • ソースコードを自分なりに変更した
  • 知人に聞いた
  • その他
上記の詳細・結果

補足

特になし

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

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

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

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

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

guest

回答1

0

ベストアンサー

公式リファレンスを見てみましたが、
https://learn.microsoft.com/ja-jp/office/vba/api/word.find
With range.Findrange.Findで返されるFindオブジェクトには、.rangeというメソッドもプロパティーもないので、そういうエラーメッセージになるのでしょう。
参考にしたページからコピペする時に何らかの間違いがあったとかですかね。
コピペじゃなくて手打ちなら、With ~ End Withの中で.から打てばその後に続けられるメソッドやプロパティーの候補がリストで出てくると思いますが、それを無視して、rangeと打っちゃったと言うことでしょうが、リストに出てこないものはそこでは使えませんよ。

VBAを書くなら、よほど簡単なもの以外は公式リファレンスを見ながらでないと困難だと思いますよ。

投稿2024/07/04 10:24

otn

総合スコア85458

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

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

Usushio166

2024/07/04 10:36

ありがとうございます 何かの影響かわかりませんが、先程まで予測変換が出ていなかったみたいでした コードを書き換えつつもう少し考えてみようかと思います!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.40%

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

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

質問する

関連した質問