前述
公開しているアプリのレーティングの変化に気づけないため、AppStoreのWebサイトをスクレイピングしてレーティングを取り出しSlackへ通知することにしました
実装
Google スプレッドシートを作成し、ツール > スクリプト エディタを選択
data:image/s3,"s3://crabby-images/58a9f/58a9faf2e0e356eaf7757ad29a38213b53a2d28e" alt="スクリーンショット 2020-03-03 22.15.42.png"
スクリプト エディタでコーディング
data:image/s3,"s3://crabby-images/aad3c/aad3c2c014d60f4e1ac7cf939cf72e2769372731" alt="スクリーンショット 2020-03-03 22.17.04.png"
トリガーを追加
スクリプト エディタ上の時計アイコンをクリック
以下のようにトリガーを作成して完了
data:image/s3,"s3://crabby-images/32d28/32d286ed3a0ada887a94084a675e24f4a2c18710" alt="スクリーンショット 2020-03-03 22.19.33.png"
実際のソース
function sendRatingCount() {
var ratingCount = fetchRatingCount();
if (ratingCount == null) {
return;
}
var now = new Date();
var date = Utilities.formatDate(now, 'Asia/Tokyo', 'yyyy年MM月dd日');
sendSlack(date + "\n" + ratingCount);
}
function fetchRatingCount() {
var response = UrlFetchApp.fetch("https://apps.apple.com/jp/app/stockey/id1407877357");
var responseCode = response.getResponseCode();
if (responseCode != 200) {
return null;
}
var contentText = response.getContentText("utf-8");
var regexp = /<figcaption class="we-rating-count star-rating__count">(.*?)<\/figcaption>/;
try {
var ratingCount = contentText.match(regexp);
return ratingCount[1];
} catch (e) {
return null;
}
}
function sendSlack(text) {
var payload = {
"text" : text
};
var options = {
"method" : "post",
"muteHttpExceptions": true,
"payload" : JSON.stringify(payload)
};
UrlFetchApp.fetch("https://hooks.slack.com/services/.....", options);
}