こんにちは、普段はUX・UIデザイナーをしているしんぺいと言います。
今回、非エンジニアの僕がほぼ「ChatGPT」頼りで簡単なアプリケーションを作ってみました。
毎日雑学botを作ってみる
雑学詳しい人ってなんかカッコ良いですよね。
知的な大人に憧れて「1日1ページ、読むだけで身につく世界の教養3651日1ページ、読むだけで身につく世界の教養365")」という本を買ったこともありましたが、そもそも1日1ページ、読むのハードルが高すぎでした。持ち歩くのに本でかいし。
なんでこの度、改めて雑学王を目指し「毎日Wikipediaの記事がランダムで届く」アプリを作ろうと思います!!
とりあえずChatGPTに聞いてみる
本当ならAPIの仕様調べたりするんでしょうが、今回は完全ChatGPT様に聞いてみる。
「node.jsでwikipedia APIを使ってURLはランダムで出力する方法を教えてください」
結果
const axios = require('axios');
async function getRandomWikipediaUrl() {
try {
// Wikipedia APIのランダムな記事エンドポイント
const apiUrl = 'https://en.wikipedia.org/w/api.php?action=query&list=random&rnnamespace=0&rnlimit=1&format=json';
// Wikipedia APIにリクエストを送信
const response = await axios.get(apiUrl);
// レスポンスからランダムな記事のタイトルを取得
const pageTitle = response.data.query.random[0].title;
// ランダムな記事のURLを構築
const wikipediaUrl = `https://en.wikipedia.org/wiki/${encodeURIComponent(pageTitle)}`;
// 結果を返す
return wikipediaUrl;
} catch (error) {
console.error('Error fetching data from Wikipedia API:', error.message);
throw error;
}
}
// ランダムなWikipedia記事のURLを取得する
getRandomWikipediaUrl().then((url) => {
console.log('Random Wikipedia URL:', url);
});
無事ランダムでWikipediaの記事を取得することができました。賢い。
続いてLine 通知が来るようにしてみる
このURLをLine Notifyで毎日通知が届くようにしてください
const axios = require('axios');
// Line Notifyのアクセストークン
const lineNotifyToken = 'YOUR_LINE_NOTIFY_ACCESS_TOKEN';
async function getRandomWikipediaUrl() {
try {
// Wikipedia APIのランダムな記事エンドポイント
const apiUrl = 'https://en.wikipedia.org/w/api.php?action=query&list=random&rnnamespace=0&rnlimit=1&format=json';
// Wikipedia APIにリクエストを送信
const response = await axios.get(apiUrl);
// レスポンスからランダムな記事のタイトルを取得
const pageTitle = response.data.query.random[0].title;
// ランダムな記事のURLを構築
const wikipediaUrl = `https://en.wikipedia.org/wiki/${encodeURIComponent(pageTitle)}`;
// 結果を返す
return wikipediaUrl;
} catch (error) {
console.error('Error fetching data from Wikipedia API:', error.message);
throw error;
}
}
async function sendLineNotification(message) {
try {
// Line Notifyにメッセージを送信
await axios.post('https://notify-api.line.me/api/notify', `message=${message}`, {
headers: {
'Content-Type': 'application/x-www-form-urlencoded',
'Authorization': `Bearer ${lineNotifyToken}`,
},
});
} catch (error) {
console.error('Error sending Line Notify:', error.message);
throw error;
}
}
// ランダムなWikipedia記事のURLを取得してLine Notifyに通知
getRandomWikipediaUrl().then((url) => {
sendLineNotification(`Random Wikipedia URL: ${url}`);
});
あとは日本語記事に限定したり、タイトル変えたりくらいで、無事、毎日雑学ベータ版ができました!(毎日手動で実行すれば笑)
いやー30分くらいでここまでできちゃうのは本当すごい。
![](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.ap-northeast-1.amazonaws.com%2F0%2F3618353%2Fa5698a27-46a1-870c-173f-130ef501b04a.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=c90fc22bcbf3370de3b881be769f6d76)
今回返ってきた記事は下記のようなものだったんですが、地名だけだと何の雑学にもならないのである程度ジャンルを絞った方などしたほうが良いかなと思うので、そこは今後改善ですね。
何にせよ、ChatGPT頼りでもちゃんと動くアプリができたことは感動でした!