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

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

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

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

Chrome

Google Chromeは携帯、テレビ、デスクトップなどの様々なプラットフォームで利用できるウェブブラウザです。Googleが開発したもので、Blink (レンダリングエンジン) とアプリケーションフレームワークを使用しています。

iframe

HTMLのタグ<iframe>です。<iframe>は、ドキュメント内に""inline frame""を作るHTML要素で、同じページでセパレートしているドキュメントが表示されるようにします。

selenium

Selenium(セレニウム)は、ブラウザをプログラムで作動させるフレームワークです。この原理を使うことにより、ブラウザのユーザーテストなどを自動化にすることができます。

Q&A

解決済

1回答

5452閲覧

vba seleniumで単一のiframe内を取得する

HoneyCase

総合スコア13

VBA

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

Chrome

Google Chromeは携帯、テレビ、デスクトップなどの様々なプラットフォームで利用できるウェブブラウザです。Googleが開発したもので、Blink (レンダリングエンジン) とアプリケーションフレームワークを使用しています。

iframe

HTMLのタグ<iframe>です。<iframe>は、ドキュメント内に""inline frame""を作るHTML要素で、同じページでセパレートしているドキュメントが表示されるようにします。

selenium

Selenium(セレニウム)は、ブラウザをプログラムで作動させるフレームワークです。この原理を使うことにより、ブラウザのユーザーテストなどを自動化にすることができます。

0グッド

0クリップ

投稿2021/10/12 08:01

編集2021/10/12 14:46

vbaとseleniumを使ってヤマトビジネスメンバーズでのcsvダウンロードの自動化を行おうとしております。

出荷データを選択までは完成しているのですがiframeで開かれるダウンロードのページの取得がうまくいかないため
方法を教えていただけないでしょうか。

vba

1Sub csvDL() 2 3With browser 4 .Get "https://bmypage.kuronekoyamato.co.jp/" 'ログイン画面 5 Call login 6 Call wait("#issue_search > div > a") 7 .FindElementByCss("#issue_search > div > a").Click 8 .FindElementByCss("#Search").Click 9 Call wait("#issue_data_btn") 10 .FindElementByClass("allCheck").Click 11 .FindElementByCss("#issue_data_btn").Click 12 .SwitchToFrame ("fancybox-frame111111111111111") 'fancybox-frameの後に乱数があるためどう要素を書けばいいのかわからない 13 14 Call wait("#output_file") 15 .FindElementByCss("#output_file").Click 16 Call wait("body > div.ui-dialog.ui-widget.ui-widget-content.ui-corner-all.ui-front.font_setting.ui-draggable.ui-dialog-buttons > div.ui-dialog-buttonpane.ui-widget-content.ui-helper-clearfix > div > button > span") 17 .FindElementByCss("body > div.ui-dialog.ui-widget.ui-widget-content.ui-corner-all.ui-front.font_setting.ui-draggable.ui-dialog-buttons > div.ui-dialog-buttonpane.ui-widget-content.ui-helper-clearfix > div > button > span").Click 18 19 20End With 21 22MsgBox "印刷完了後OKを押してください" 23Set browser = Nothing 24End Sub

動作テストでは直でidを入力で動いたのですが
fancybox-frame以降に乱数が入るため
要素をどう宣言すればいいのかわかりません。

///試したこと///

vba

1.SwitchToFrame ("fancybox-frame") 2.SwitchToFrame ("fancybox-frame*") 3.SwitchToFrame ("fancybox-frame"&*)

曖昧な宣言が出来ないかためしましたが上記の3種はいずれもダメでした。

何か解決方法はありますでしょうか。よろしくお願いします。

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

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

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

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

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

guest

回答1

0

ベストアンサー

iframeが1つなら、
.SwitchToFrame .FindElementByTag("iframe")
では?

投稿2021/10/12 11:11

otn

総合スコア84491

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

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

HoneyCase

2021/10/12 14:44

回答ありがとうございます。 無事iframeを内も自動化できるようになりました。 ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.49%

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

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

質問する

関連した質問