スクレイピング

PaaSを触り始めてから1番やってみたかったことと言えば、Webサイトのスクレイピング。
別に攻撃するつもりじゃ無くて、マッシュアップしたWeb上の情報を上手く可視化すれば、色んな考察が得られるんじゃないかと期待しているから。
そう思ったきっかけはKakeibonっていう無料で使える自動ネット家計簿を知ったから。(以前はOCN家計簿って名前だった)
このサイトは、銀行口座やクレジットカード、ECサイトなどの情報を引っ張ってきて収支をグラフにまとめてくれる。
銀行もクレジットカードも、それぞれのポータルサイトはAPIなんて公開していないので、おそらくスクレイピングで実現している。
既存の情報を上手く使うだけで色んなことが見えてくるんだなぁ、と感心した。

ということで、しばらくスクレイピングについて調べていたのである。ちょっと調べてみると、フロントでもサーバサイドでもできるし、色んな言語で実装できるので、どこから手を付けたらいいのかちょっと悩むレベルで選択肢が豊富。やるとしたらサーバサイドだけど、サーバサイドはどの言語が1番組み合わせやすいかちょっと自分の知見が足りてない。

こういうのは結構需要があるみたいで、スクレイピングするコードの共有や、スクレイピングしたデータをAPI化するサイトもあるみたい。

ScraperWiki

ScraperWikiはイギリスのスタートアップ企業で、スクレイパーコードを共有するサイトを提供しています。
開発者達はサイト上から直接コード(Ruby, PHP, Python)を編集、実行することができます。スクレイプを定期的に実行することも可能で、取得されたデータはScraperWikiに保存されますが、ScraperWikiはAPIを用意しているので、このAPIを通して、他のサイトでデータを再利用することが可能です。
「Wiki」といっているだけあって、一般公開されているコードは他の人も編集したり、またコードをコピーして他のスクレイピングに利用することもできます。定期的に実>行されているスクレイパーがエラーを起こしていないかをチェックする仕組みがあり「みんなでスクレイピングを管理」するための仕組みがいたるところにあります。
ScraperWikiは、もともとイギリスで、どの議員がどの法案に賛成または反対票を投じたかを議会のサイトから創業者の一人が2003年頃にスクレイプしたことを起源に持ちます。

スクレイピングするなら ScraperWiki 使うといいよ

kimono
指定したウェブサイトをスクレイピングしてAPI化してくれるサービス「kimono」

さて、地道に勉強するか。

関連記事

iPhone・iPod touchで動作する知育ロボット『ROMO』

OpenCV 3.1から追加されたSfMモジュール

Gource:バージョン管理の履歴を可視化するツール

Math.NET Numerics:Unityで使える数値計算ライブラリ

SONYの自律型エンタテインメントロボット『aibo』

JavaScriptとかWebGLとかCanvasとか

OpenGVの用語

OpenCVで平均顔を作るチュートリアル

CGレンダラ研究開発のためのフレームワーク『Lightmetrica (ライトメトリカ)』

Python for Unity:UnityEditorでPythonを使えるパッケージ

trimesh:PythonでポリゴンMeshを扱うライブラリ

Dlib:C++の機械学習ライブラリ

オープンソースの人体モデリングツール『MakeHuman』のAPI開発プロジェクトがスタート

Amazon Web ServicesでWordPress

2D→3D復元技術で使われる用語まとめ

スクラッチで既存のキャラクターを立体化したい

FCN (Fully Convolutional Network):ディープラーニングによるSema...

Google App Engineのデプロイ失敗

Twitter APIのPythonラッパー『python-twitter』

Unreal Engineの薄い本

機械学習に役立つPythonライブラリ一覧

第1回 3D勉強会@関東『SLAMチュートリアル大会』

Pylearn2:ディープラーニングに対応したPythonの機械学習ライブラリ

Kaolin:3Dディープラーニング用のPyTorchライブラリ

WordPress on Google App Engineを1週間運用してみて

konashiのサンプルコードを動かしてみた

Amazon EC2ログイン用の秘密鍵を無くした場合の対処方法

SVM (Support Vector Machine)

ブログの復旧が難航してた話

Iridescence:プロトタイピング向け軽量3D可視化ライブラリ

R-CNN (Regions with CNN features):ディープラーニングによる一般物体...

ZBrushで作った3Dモデルを立体視で確認できるVRアプリを作る

HerokuでMEAN stack

プログラミングスキルとは何か?

WordPressの表示を高速化する

COLMAP:オープンソースのSfM・MVSツール

AfterEffectsプラグイン開発

ディープラーニング

PythonでBlenderのAdd-on開発

LuxCoreRender:オープンソースの物理ベースレンダラ

iOSで使えるJetpac社の物体認識SDK『DeepBelief』

WordPress on Windows Azure

コメント