実現したいこと
pythonで情報収集ツールを作っています。QWebEngineViewを使いURLアクセスし動的HTMLの解析しているのですが、
画像の保存機能がないかなと思い質問しました。つまりEdgeのようなブラウザでHPを保存すると
Imageもセットで保存されます。今回欲しいのはImageでして、ページ遷移の都度、HPを丸ごと保存し、最終的に全部消すみたいな処理を実現したいです。
発生している問題・分からないこと
AIに聞いたところJavaScriptで画像にアクセスし、ダウンロードする方法を進められました。
試行錯誤しましたが、結局取得はできません。CORS(Cross-Origin Resource Sharing)エラーになり頓挫しました。WebDriverは使用禁止のルールがあります。QWebEngineViewに表示しているのだから、
Requestは使わず、表示している内容を取得できないものかとおもっています。
該当のソースコード
class Browser(QMainWindow): #初期化関数 def __init__(self): super().__init__() # ユーザーエージェントの設定 profile = QWebEngineProfile.defaultProfile() self.strUserAgent = "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.110 Safari/537.3" profile.setHttpUserAgent(self.strUserAgent) # ウィジェットの初期化 self.browser = QWebEngineView() self.url_label = QLabel("Current URL: ") # URL表示用のラベル self.browser.loadFinished.connect(self.on_load_finished) <省略> def on_load_finished(self, success): if success: # ページが読み込まれた後、クッキーを取得する self.get_cookies() self.save_image_from_page() #←これを実現したい。 ※on_load_finishedで、ホームページに表示されている画像をすべて保存したい。 追加Requestは発生しないやり方が知りたい
特になし
試したこと・調べたこと
- teratailやGoogle等で検索した
- ソースコードを自分なりに変更した
- 知人に聞いた
- その他
上記の詳細・結果
AIの力をかりて、JavaScriptで、家電ショップの画像をダウンロードする処理をつくったんですが、CORS(Cross-Origin Resource Sharing)エラーになり頓挫しました。
補足
特になし
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。