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

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

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

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

Q&A

解決済

1回答

2559閲覧

マクロにてセルの文字をGoogle検索したい

Naoko_Coco

総合スコア54

VBA

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

0グッド

0クリップ

投稿2019/05/23 02:19

マクロにてセルクリックしたらそのWordをGoogle検索したいです。
FollowHyperlinkを使用するようなのですが、他のページからのコピペでもYahoo検索はできるのですが。
これをGoogle検索”http://www.google.co.jp/search?q=”にWordを追加すると途端にできなくなります。
他の方もGoogle検索のSampleコード載せてくれているのですが、それも同じようなエラーになります。

VBA

1Sub serchtest() 2 3Dim word As String 4Dim URL As String 5 6word = Selection.Text 7URL = "http://www.google.co.jp/search?q =" & word 8'---エラーメッセージ オブジェクトが必要です 9ActiveDocument.FollowHyperlink Address:=URL, NewWindow:=True 10 11End Sub

下記はそのまま書き込んでみました。

VBA

1Sub serchtest2() 2 3Dim strURL 4 5strURL = "http://www.google.co.jp/search?q=VBA" 6'---エラーメッセージ 必要な情報をダウンロードできません 7ActiveWorkbook.FollowHyperlink Address:=strURL, SubAddress:="", NewWindow:=True 8 9End Sub

strURLがネットで見つけた元々のURL"https://www.softel.co.jp/blogs/tech/"にするとちゃんと表示されます。
"http://www.google.co.jp”もちゃんと表示されます。
serchを入れると

’FollowHyperlink’は失敗しました。’_WorkBook’オブジェクト

他に付け足さなきゃいけない関数とかがあるのでしょうか?
検索はしてるのですが思った記事が見つからないです。
よろしくお願いします。

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

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

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

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

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

tetsunosuke

2019/05/23 02:27 編集

手元の環境ではうまく動きました。(MacのExcelですが・・・) strURL は http://www.google.co.jp/search までにしておいて、 ActiveWorkbook.FollowHyperlink Address:=strURL, SubAddress:="", ExtraInfo:="q=VBA2", NewWindow:=True このように、ExtraInfoとしてクエリを渡したらどうでしょうか?
Naoko_Coco

2019/05/23 02:51

tetsunosukeさん ありがとうございます。 http://www.google.co.jp/searchまでならWEBは開きます。 ExtraInfoつけるとFollow・・・失敗しました。になりますね。。。 どうもURLの文字列をjavascriptでUTF-8にエンコードするとって記事を見つけたのでちょっとやってみます。
tetsunosuke

2019/05/23 02:52

なるほど。例に出してもらっている VBA はうまくいくけど 日本語だとダメ、ということですか!
Naoko_Coco

2019/05/23 03:03

ExtraInfo:="q=VBA2でも試したのですがうまくいきませんでした。
Naoko_Coco

2019/05/23 03:50

依存とかそういうものなんでしょうかね???
guest

回答1

0

自己解決

検索をしていて他の方があげてる方法にしました。
テキストが日本語の場合、エンコードしてあげなきゃいけないようです。
このようなやり方を初めて知りました!

VBA

1'Googleサーチ 2Sub Google_serch() 3 4Dim word As String 5Dim url 6word = Selection.Text 7url = "https://www.google.co.jp/search?q=" & UrlEncodeUtf8(word) 8 9CreateObject("wscript.shell").Run url 10End Sub

VBA

1'UTF-8にエンコードする 2Function UrlEncodeUtf8(ByRef strSource As String) As String 3Dim objSC As Object 4Set objSC = CreateObject("ScriptControl") 5objSC.Language = "Jscript" 6UrlEncodeUtf8 = objSC.CodeObject.encodeURIComponent(strSource) 7Set objSC = Nothing 8End Function

投稿2019/05/23 03:54

Naoko_Coco

総合スコア54

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

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

tetsunosuke

2019/05/23 04:54

日本語ではない場合もうまくいかなかったと書いてあったので若干腑に落ちないのですが...まあ解決したのであればよかったです。
Naoko_Coco

2019/05/23 05:18

tetsunosukeさん ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問