ここから本文です

excelのの住所録から緯度経度を求めたいと思っています。 よろしくおねがいします...

gu0********さん

2014/1/2910:16:31

excelのの住所録から緯度経度を求めたいと思っています。
よろしくおねがいします。

http://www.simple-sys.com/blog/2008/04/06/301/
上記ページを参考に、excelの住所録から緯度経度を求めたくて作成中です。

上記ページで、イミディエイトに「pの文字列」を求めることと「緯度経度」の抜き出しまではできました。
ですが、最後のA列全部を見てBセルとCセルに値を入力するところでエラーが出てしまいます。
エラーは「アクセス拒否されました」と最初に出て、続いて「エラー70’書き込みできません」と出ます。

VBA勉強中で何か知識が足りないみたいで、どうしてもうまくいかないんです。
パソコンはwindows7、excel2010を使用しています。

どなたかよろしくお願いします。

この質問は、活躍中のチエリアン・専門家に回答をリクエストしました。

閲覧数:
6,672
回答数:
1
お礼:
50枚

違反報告

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

yam********さん

2014/1/2918:09:15

ご提示のサイトのプログラムはMSXML2.XMLHTTPを使用しています。
以前は良かったような記憶がありますがYahooサイトはアクセスの拒否しています。
また、responseの投稿コードは間違いがあり、正しく動作しません。
InternetExplorer.Applicationでできるか確認しましたが敷居は高そうです。
GoogleMapを利用すると容易に行えました。
A列に住所(番地まで正確に)を入れたら下記のマクロを実行してください。

Sub GetLatLonFromGoogleMap() 'A列1行目から住所(番地まで)を入力、B列に緯度、C列に経度
Dim objIE As Object
Dim obj As Object
Set objIE = CreateObject("InternetExplorer.Application")
For i = 1 To Cells(Rows.Count, 1).End(xlUp).Row
objIE.Navigate "http://www.google.co.jp/maphp?hl=ja&tab=wl&q=" & Cells(i, 1)
Do While objIE.ReadyState <> 4
Do While objIE.Busy = True
Loop
Loop
myStr = objIE.document.body.innertext
Cells(i, 2) = Mid(myStr, InStr(myStr, "lat=") + 4, 13)
Cells(i, 3) = Mid(myStr, InStr(myStr, "lng=") + 4, 14)
Next
objIE.Quit
Set objIE = Nothing
End Sub

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

2014/1/30 14:48:54

できました!
感動しました、すっごく悩んでいたので本当に嬉しいです。

前のリンクのコードができない理由まで書いてくださってありがとうございます!
VBAは難しいですが、できたときの感動が楽しいですね。
これからもっと勉強していきたいと思います。
ありがとうございました。

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

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

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

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

閉じる

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

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

閉じる