バイクが好きだ!と公言し、Qiita初投稿テーマとして「【JavaScript活用】QiitaAPIを活用してバイク好きがいるか調べてみた」を投稿しましたが、「さいごに」に記載したとおり、英語圏ではオートバイを指す言葉は[bike]ではなく [Motorcycle] なのだということがわかりました。
それならやることはひとつよね~。ということで [Motorcycle] でリベンジ しますッ
#リベンジ内容
せっかくのリベンジなので、少しチャレンジングな内容もやってやろうじゃないか!
ということで、前回からの処理条件の追加・変更箇所を赤字として記載したとおりに実行します。
なお、処理の順番も変更していますがわかりにくくなるので赤字にしていません。
(条件変えただけでCsv書き出しを追加したくらいしか変わっていないのはご容赦ください)
【検索するタグおよびキーワード】
・ [Motorcycle]
【処理】
1.タグのフォロワー数をそれぞれ取得
2.タグが設定された記事数をそれぞれ取得
3.キーワードが含まれた記事のタイトル、URL、 LGTM(=いいね!) を10件分を一覧化
4. Csv書き出し (キーワードが含まれた記事のタイトル、URL、LGTM(=いいね!)を100件分)
#環境、言語等
・Visual Studio Code
・Qiita API
・JavaScript
・Node.js
#処理コードおよび処理結果
「タグをフォローしている人の数」「タグを含む記事の数」の処理がエラーが出て、どうにもこうにも動かない。単語を変えてやると問題なく動くのに、[Motorcycle]でやるとエラーが出ます。
もしかして?タグの存在がそもそも存在しないとエラーになるのかな?と思い、エラー回避「try~catch文」を実装することにしました。
Csvへ書き出す処理もチャレンジします!
★参考:【JavaScript】例外処理try~catch文の使い方
★参考:JSONの基本 データ形式
##タグのフォロー数、タグを含む記事数、キーワード記事10件分
###処理コード
//定数を各種定義し代入
const axios = require('axios');
const accessT = '自分のアクセストークンを指定';
const NameEnglish = 'Motorcycle';
//関数mainを定義
async function main() {
//★[Motorcycle]タグをフォローしている人の数
try{
let response1 = await axios.get('https://qiita.com/api/v2/tags/Motorcycle', {
headers: {
'Authorization': `Bearer ` + accessT
}
});
console.log('1[' + NameEnglish + ']タグのフォロワー数:'+ response1.data.followers_count);
} catch(e) {
}
//★[Motorcycle]タグを含む記事の数
try{
let response2 = await axios.get('https://qiita.com/api/v2/tags/Motorcycle', {
headers: {
'Authorization': `Bearer ` + accessT
}
});
console.log('2[' + NameEnglish + ']タグを含む記事数:'+ response2.data.items_count);
} catch(e) {
}
//★[Motorcycle]をキーワードとして含む記事の一覧20件分(Title,URL,LGTM数)
let response3 = await axios.get('https://qiita.com/api/v2/items?per_page=10&page=1&query='+ NameEnglish, {
headers: {
'Authorization': `Bearer ` + accessT
}
});
console.log('| Title | URL | LGTM数 |');
console.log('|:-|:-|:-:|');
for (let i = 0; i < response3.data.length; i++) {
//ログを表示させるのみ
console.log('|'+ response3.data[i].title +'|'+ response3.data[i].url +'|'+ response3.data[i].likes_count +'|');
}
}
main();
###処理結果
[Motorcycle]タグは存在していないようですね・・・
エラー回避が作用処理はうまく作動しましたのでよかったです!
そのあとの[Motorcycle]キーワードの一覧もコンソールログ表示もうまく動きました。
####[Motorcycle]タグをフォローしている人の数
1[Motorcycle]タグのフォロワー数:0
####[Motorcycle]タグを含む記事の数
2[Motorcycle]タグを含む記事数:0
####[Motorcycle]をキーワードとして含む記事の一覧10件分(Title、URL、LGTM数)
10件分
##Csv書き出し(キーワードが含まれた記事のタイトル、URL、LGTM(=いいね!)を100件分)
一から書いてみようと思いましたが、やっぱり難しく以下記事を参考にさせていただきました。
前回できなかったCsv書き出しが無事に動いたので、いったんリベンジ完了です
★参考:JavaScriptとQiitaAPIで取得した人気タグ情報をplotlyで散布図表示してみる
###処理コード
//package require
const axios = require("axios");
const fs = require("fs");
const csvStr = require("csv-stringify/lib/sync");
const csvParse = require('csv-parse/lib/sync');
const NameEnglish = 'Motorcycle';
const accessT = '自分のアクセストークンを指定';
//QiitaAPIでデータ取得・csvに出力
async function getArticle(query) {
//csvに変換する用list
let outcsv = [];
//csvのヘッダー設定
let columns = ['Title','URL','LGTM'];
outcsv.push(columns);
let response
//リクエストが失敗した時の処理
response = await axios.get('https://qiita.com/api/v2/items?per_page=100&page=1&query=' + NameEnglish, {
headers: {
Authorization: `Bearer ` + accessT,
}
}
).catch(err => {
return err.response
});
if (response.status != 200) {
console.log("APIエラーとは・・・?")
}
//Csv書き出し準備
for (let i = 0; i < response.data.length; i++) {
//listに格納
let record = [];
record.push(response.data[i].title,response.data[i].url,response.data[i].likes_count);
outcsv.push(record);
}
//Csvとして出力
fs.writeFileSync('./list_'+ NameEnglish +'.csv', csvStr(outcsv));
}
//情報の取得
var query = "node.js";
getArticle(query);
###処理結果
Visual Studio Codeで中を開くと、Csv形式になっていましたわーい!(画像上は途中省略しています。)
100件上限にしましたが67件しかないことが判明しました
Explorer上Csvファイルが保存されていることも確認できました。
Csvファイルを開くと文字化けしておりました。リベンジ完了と書きましたが、文字化け回避リベンジが必要ですねうおぉぉぉ!!!
#考察
10件分のリスト化されたURL先の文書を見ての考察といたします。
・物体認証AIのディープラーニングの返り値がバイク=[Motorcycle]となっているので[Motorcycle]がヒットしているだけの記事が多数存在。
・Motorcycleクラスという謎の単語が出てきた。(別途調べようと思います。)
・[Motorcycle]=バイクが好きだということで投稿している文書は見つからなかった。
・日本語の記事は[Motorcycle]より[バイク]・[bike]をキーワードとして用いることが多いと推測。
・バイクが好きな人はキーワードとして[バイク]を使っていると推測。
#さいごに
日本語としては[Motorcycle]という言葉を文章内に使うことが少ないことがわかりました。
バイクが好きな人はキーワードとしては[バイク]を使っているのかな、と思います。
確かに会話の中で「私はMotorcycleが好き!」とは言わないかも。
今回は単純にCsv書き出しをリベンジ しましたが、文字化け回避はリベンジしたい・・・
色々チャレンジしながらステップアップしたいです!
ついでに折り畳みもリベンジできました
#記事の書き方で参考にしたURL
記事名(サイト表題) | URL |
---|---|
Qiitaの投稿で装飾したいときによく使うHTMLタグ | https://qiita.com/7note/items/9c0763d5491e43edb552 |
絵文字チートシート | https://www.webfx.com/tools/emoji-cheat-sheet/ |
WEB色見本 原色大辞典 - HTMLカラーコード | https://www.colordic.org/ |