Creazy!

WEBエンジニア・ヤガーのテック・ガジェットブログ

技術情報

勝手に添削:bookmarklet – ページに含まれるURLを抽出してTSVにする

投稿日:


一回やってみたかったんだ、「勝手に添削」
しかも、dankogaiさんの(笑)
お題は下記です。
CodeZine:Webページに含まれるURLを抽出し、Excelにまとめて保存する(HTA)
404 Blog Not Found:bookmarklet – ページに含まれるURLを抽出してTSVにする
IEだけじゃイカンという意味では、danさんの記事に賛成。
ですが、

例えばSafari3では下がうまく行かず(ウィンドウに何も表示されない)、Firefox2では上がうまく行きません(一行しかpromptに入らない)。OperaはどちらもOK(優秀!)。IEは未確認(報告お願いします)。ブラウザーにあわせて使い分けて下さい。

via: 404 Blog Not Found:bookmarklet – ページに含まれるURLを抽出してTSVにする

というわけで、クロスブラウザになってませんねw
FFのpromptに複数行の文字列を入れられないのはどうしようもないので、別ウィンドウに開く場合にSafariで動かない件に対応してみましょう。
Extract Links as TSV (window)

javascript:(function(){w=window.open('','');d=w.document;d.open();d.write('<plaintext>'+(function(a){var r=[];for(var i=0;i<a.length;i++)r[i]=a[i].innerHTML+'\t'+a[i].href;return r.join('\n');})(document.getElementsByTagName('A')));d.close();})();

多分、document.open();document.close();を省略したのがマズかったんじゃないかと思います。あと、voidで全部を囲ってるのもあやしいかったけど、とりあえず上記で、IE/FF/Safari動きます。
更に、上記で出力したページからWin+IEで小ピーしてExcelにはりつけてもうまくセルに合わなかったので、<plaintext>じゃなくて<textarea>に出力したらうまくいきました。
‘+(function(a){var r=[];function e(s){return s.replace(//g,’&gt;’);}for(var i=0;i ‘+e(a[i].innerHTML)+’ ‘+e(a[i].href)+’

‘;return r.join(”)+’‘;})(document.getElementsByTagName(‘A’)));d.close();})();”>Extract Links as TSV (window+table)

javascript:(function(){w=window.open('','');d=w.document;d.open();d.write('<ta'+'ble border=1>'+(function(a){var r=[];function e(s){return s.replace(/</g,'&lt;').replace(/>/g,'&gt;');}for(var i=0;i<a.length;i++)r[i]='<tr><td>'+e(a[i].innerHTML)+'</td><td>'+e(a[i].href)+'</td></tr>';return r.join('')+'</ta'+'ble>';})(document.getElementsByTagName('A')));d.close();})();

enjoy!

-技術情報

執筆者:


comment

メールアドレスが公開されることはありません。

関連記事

no image

MacBookのファンが壊れてGENIUS BARに入院→退院

先月、自分でMacBookのハードディスクを160GBから500GBに交換したばかりなのですが、その後しばらくたってからMacBookからものすごい異音がでるようになってしまいました。位置的には空冷用 …

no image

CotEditorのスクリプトメニューでPHPを起動する方法(便利なサンプル3つ付き)

なんか、エディタの話ばっかりでスミマセンw 秀丸 for Macに思いを馳せつつも、いまんとこMacのエディターはCotEditorで落ち着いてます。シンタックスカラーはもちろんのこと、dankoga …

mixi日記やGREE日記をPCのメーラーから更新する方法

っていうか、「RSS2GREE」のエントリーにほとんど書いてあるんですけど、見落としている方がいるかもしれないので。 メールの送信元(from:)を自分の携帯メールアドレスにするGREEのメール投稿機 …

no image

CakePHPカンファレンス東京:参加レポート

CakePHPカンファレンス東京 events.php.gr.jp – CakePHPカンファレンス東京 10/25(土)に参加したCakePHPカンファレンス東京のレポートを書こうと思い …

Adobe Photoshop Express と Flickr が連携しました

先日β版の公開を紹介したPhotoshop Expressですが、待望のFlickrとの連携機能をスタートしていました。 アドビ システムズは米国時間5月9日、先週予定されていた同社プログラム「Pho …

スポンサードリンク

スポンサードリンク