ブラウザ操作自動化ツール『Selenium』を試す

だいぶ前にSeleniumの存在を知っておきながら、まともに試さず時間が経った。



Selenium WebDriverをPythonから叩けばスクレイピングもお手軽だよなぁ、と思い始めた。
Python環境でもpipで簡単にSeleniumをインストールできる。
ブラウザはChromeを使いたいので、別途ブラウザ用のWebDriverとしてChromeDriverもダウンロードした↓
https://sites.google.com/a/chromium.org/chromedriver/

PythonからWebDriverの実行ファイルを叩くような使い方をするらしい。
スクレイピングでSeleniumを使う1番のメリットは、ログインが必要なサイトや、JavaScriptの実行を求めるサイトでも普通のブラウザ操作としてコードが書ける点。複雑なWebの仕組みを抽象化するためにブラウザを間に噛ます感じ。(全部コーディングでやろうとして苦労したことがある…)
Seleniumでサイトのデータを粗く取得して、Beautiful Soupなどのライブラリで詳細にtextをパースしていけば良いんじゃないかな。
https://blog.negativemind.com/2014/06/15/python%E3%81%AE%E3%82%B9%E3%82%AF%E3%83%AC%E3%82%A4%E3%83%94%E3%83%B3%E3%82%B0%E3%83%A9%E3%82%A4%E3%83%96%E3%83%A9%E3%83%AA%E3%80%8Ebeautifulsoup%E3%80%8F/


スポンサーリンク


始めるにあたって参考にしたのはこちら↓
http://nfnoface.hatenablog.com/entry/2017/03/08/212300
https://dev.classmethod.jp/tool/eclipse/windows-selenium-headless-chrome/

何で急にスクレイピングの勉強を再開したかと言うと、最近は機械学習を手軽に試せるライブラリが充実してきたのに、手元にあんまり面白いデータが無かったから。
そして、個人のPCで試せる程度の演算負荷と考えると、画像よりもtextデータの方が色々と試行しやすい気もしている。単位時間あたりに沢山試せた方が学びがあるんじゃないかな。

スクレイピングや言語処理にはそれほど詳しくないんだけど、幸い広く浅く紹介している書籍の存在を知った。↓

Pythonによるスクレイピング&機械学習 開発テクニック BeautifulSoup,scikit-learn,TensorFlowを使ってみよう

画像認識にニューラルネットワークを使う理屈は何となく知ってるけど、言語処理については全く知らないので勉強してみたくなった。

最近Qiitaによく使う正規表現のまとめ記事がアップされたので助かる。
https://qiita.com/dongri/items/2a0a18e253eb5bf9edba


スポンサーリンク

関連記事

libigl:軽量なジオメトリ処理ライブラリ
cvui:OpenCVのための軽量GUIライブラリ
Cartographer:オープンソースのSLAMライブラリ
Point Cloud Utils:Pythonで3D点群・Meshを扱うライブラリ
SONY製のニューラルネットワークライブラリ『NNabla』
2D→3D復元技術で使われる用語まとめ
Alice Vision:オープンソースのPhotogrammetryフレームワーク
ZBrushのZScript入門
タマムシっぽい質感
UnityのGameObjectの向きをScriptで制御する
Unityの薄い本
3D復元技術の情報リンク集
Raspberry PiでIoTごっこ
KelpNet:C#で使える可読性重視のディープラーニングライブラリ
openMVG:複数視点画像から3次元形状を復元するライブラリ
OpenCVでiPhone6sのカメラをキャリブレーションする
Manim:Pythonで使える数学アニメーションライブラリ
OpenFace:Deep Neural Networkによる顔の個人識別フレームワーク
OpenGVのライブラリ構成
Mitsuba 3:オープンソースの研究向けレンダラ
OpenCVで動画の手ぶれ補正
Deep Learningとその他の機械学習手法の性能比較
Raspberry Pi
FreeMoCap Project:オープンソースのマーカーレスモーションキャプチャ
Webサイトのワイヤーフレームが作成できるオンラインツール
PythonでMayaのShapeノードプラグインを作る
BlenderのPython環境にPyTorchをインストールする
法線マップを用意してCanvas上でShadingするサンプル
SDカードサイズのコンピューター『Intel Edison』
iOSデバイスのためのフィジカル・コンピューティングツールキット『konashi(こなし)』
python-twitterで自分のお気に入りを取得する
TensorSpace.js:ニューラルネットワークの構造を可視化するフレームワーク
IronPythonを使ってUnity上でPythonのコードを実行する
頭蓋骨からの顔復元と進化過程の可視化
WebGL開発に関する情報が充実してきている
OpenCVのfindEssentialMat関数を使ったサンプルを読んでみる
Raspberry PiのGPIOを操作するPythonライブラリ『RPi.GPIO』の使い方
Geogram:C++の3D幾何アルゴリズムライブラリ
Mitsuba 2:オープンソースの物理ベースレンダラ
OpenAR:OpenCVベースのマーカーARライブラリ
Math Inspector:科学計算向けビジュアルプログラミングツール
Live CV:インタラクティブにComputer Visionコーディングができるツール

コメント