Javascriptで情報を一括取得
data:image/s3,"s3://crabby-images/3c89c/3c89ce2bb0edb6e0a2e4e96e5f5b7d47e7ea8043" alt=""
「このプレイリストの曲名を全部取得したいけど、100曲以上あるからコピペがめんどくさい」みたいな時に、Javascriptを使用して一括取得する方法を紹介します。
やり方
今回はGoogle検索を例にやってみます。
まずは適当に検索。
次にページのどこかを右クリックしてデベロッパーツールを開くか、
data:image/s3,"s3://crabby-images/a6432/a6432a938e83a5e9c04f076a63ac655646c2d314" alt="記事の画像"
Windows: Ctrl + Shift + i
Mac: ⌘command + option + i
でデベロッパーツールを開きましょう。
data:image/s3,"s3://crabby-images/e975e/e975ef4c44d2a2b7968e9597e0c05594367f4882" alt="記事の画像"
デベロッパーツールの左上のマークをクリックして、対象の要素(今回はページのタイトル)のところにカーソルを持っていってクリック。
data:image/s3,"s3://crabby-images/e619a/e619a61512a3b4cc9dbae2bb7c85644de9ad7ab8" alt="記事の画像"
すると、要素を選択した状態になるので、今回でいえば全てのタイトルにつけられてそうなクラス名を探します。
クラス名をダブルクリックしてからコピーします。
data:image/s3,"s3://crabby-images/ebc98/ebc98b12d306a48c9ad8270fe01aeb6244731dfa" alt="記事の画像"
次に、「コンソール」を開いてください。
data:image/s3,"s3://crabby-images/74e8f/74e8fa1085a7d19146e2427e2e2068ebd7646b38" alt="記事の画像"
下のコードの「クラス名」となっているところを、さっきコピーしたコードと置き換えてください。
const items = [...document.getElementsByClassName('クラス名')];
let copyTxt = "";
for (let i = 0; i < items.length; i++) {
copyTxt += `\n${items[i].textContent}`;
}
copy(copyTxt);
console.log(copyTxt);
実行するとこんな画面になって赤で囲ったテキストがコピーされます。
data:image/s3,"s3://crabby-images/8750c/8750c5eb7b9cc1d1970cb2bf9443882c399a0629" alt="記事の画像"
ちなみにApple Musicのプレイリストなどの曲名を取得したい方は、次の手順でできます。
ミートボールメニュー > 共有 > リンクをコピー
data:image/s3,"s3://crabby-images/c338f/c338f96778448d9acf8f4f1126a067aa12962241" alt="記事の画像"
コピーしたリンクをブラウザで開いて、さっき説明した手順でやったらできます。
コード解説
さっきのJavascriptのコードを少し解説して終わります。
const items = [...document.getElementsByClassName('クラス名')];
let copyTxt = "";
for (let i = 0; i < items.length; i++) {
copyTxt += `\n${items[i].textContent}`;
}
copy(copyTxt);
console.log(copyTxt);
まずはこれ
const items = [...document.getElementsByClassName('クラス名')];
itemsにそのクラス名を持っている全ての要素を格納します。
[...]で囲っているのは、そのままだとNodeListになってしまうので普通の配列として格納しています。
...はスプレッド構文というもの。
ちなみにこれでも[...]と同じような処理ができます。
const items = Array.from(document.getElementsByClassName('クラス名'));
こちらは、itemsの全ての要素のtextContentをcopyTxtに追加しています。
for (let i = 0; i < items.length; i++) {
copyTxt += `\n${items[i].textContent}`;
}
\nで改行することによってみやすくなります。
最後に、copyTxtをクリップボードにコピーします。
copy(copyTxt);