実現したいこと
A2セルの値を抽出し、新しいタブでgoogleで検索、
A3セルの値を抽出し、新しいタブでgoogleで検索、
をA11セルまで(10個)行い、いったん終了。
その後、もう1度プロシージャを実行したら、
A12からA21セルについて、次の実行ではA22からA31セルについて
同様の処理がなされるようにしたい。
発生している問題・分からないこと
下記コードの実行で、
A2からA11までのセルについて新規タブで検索実行できており、その点は希望通りの動作をしています。
ただし、2回目の実行でも再度A2からA11までのセルについて処理がなされるので、
これを、A12からA21セルについて、次の実行ではA22からA31セルと処理されるようにしたいです。
該当のソースコード
Sub 質問用() Dim 検索ワード As String Dim ws As Worksheet: Set ws = Workbooks("scraping.xlsm").Sheets("sheet1") Static 行 As Long: 行 = 2 Do Until 行 Mod 12 = 0 検索ワード = ws.Cells(行, 1).Value CreateObject("WScript.shell").Run "https://www.google.com/search?q=" & 検索ワード 行 = 行 + 1 Loop End Sub
試したこと・調べたこと
- teratailやGoogle等で検索した
- ソースコードを自分なりに変更した
- 知人に聞いた
- その他
上記の詳細・結果
Staticステートメントを使うと、希望の処理ができそうだと思ったので、コードに入れてみたのですが、うまくできませんでした。
補足
特になし
10行ずつ進める方針を mod 12 で実装するのは困難だと思いますので、
for next とかの開始行と終了行を指定する方式にした方が楽かもしれません。
行カウンタはマクロを終了すると忘れられるので、2回目以降で継続動作を
させたい場合は、どこかに進行状況を記録することになると思います。
googleの利用規約をよく読んで、利用規約に違反していないことを明示しておくと
有識者が回答をつけてくれるかもしれません。
https://developers.google.com/search/docs/essentials/spam-policies?hl=ja&rd=1#machine-generated-traffic
機械生成トラフィック(略)
明示的な許可なく Google 検索に自動アクセスするその他の行為もこれに含まれます。(略)
このような行為は、Google のスパムに関するポリシーおよび Google 利用規約に対する違反となります。
https://developers.google.com/custom-search/v1/overview?hl=ja
> VBA・スクレイピング】A列に入力されているセルの値を順に抽出し、googleで検索したいです。
Googleはスクレイピングのようなアクセスは禁止だったと思うので、上記は実現不可能だと思われます。
また禁止されていない場合であっても適切な待機時間が必要ではないでしょうか?

回答1件
あなたの回答
tips
プレビュー