ساخت ربات تحلیل رقبا با استفاده از API اینستاگرام
مقدمه
در دنیای رقابتی امروز، تحلیل رقبا یک امر حیاتی برای رشد هر کسبوکار در اینستاگرام است. اگر بتوانیم فعالیتهای رقبا را بهطور دقیق بررسی کنیم، میتوانیم استراتژیهای بهتری طراحی کرده و تعامل بیشتری کسب کنیم. اما تحلیل دستی رقبا زمانبر و سخت است. راهحل چیست؟ در این مقاله یاد میگیریم چگونه با استفاده از API اینستاگرام یک ربات تحلیل رقبا بسازیم که اطلاعات رقبا را بهصورت خودکار جمعآوری و تحلیل کند.
این ربات میتواند بهصورت خودکار:
فعالیت رقبا را بررسی کند (تعداد پستها، لایکها، کامنتها و فالوورها)
بهترین زمان انتشار پست آنها را شناسایی کند
میزان تعامل (Engagement Rate) را محاسبه کند
محتوای پربازدید آنها را تحلیل کند
قدم ۱: دریافت دسترسی به API اینستاگرام
۱.۱ ایجاد اپلیکیشن در Facebook Developer
ابتدا باید از طریق Facebook Developer به API اینستاگرام دسترسی بگیریم.
- وارد Facebook for Developers شوید.
- روی Create App کلیک کنید.
- نوع اپلیکیشن را Business انتخاب کنید.
- در قسمت Permissions، این موارد را اضافه کنید:
instagram_basic
(برای دریافت اطلاعات عمومی پیج)instagram_graph_user_profile
(دریافت اطلاعات پروفایل)instagram_graph_user_media
(دریافت اطلاعات پستها)
۱.۲ دریافت Access Token
- به Graph API Explorer بروید.
- دسترسیهای لازم را اضافه کنید.
- یک توکن بلندمدت (Long-lived Token) بگیرید.
نکته: توکن را در محیطی امن ذخیره کنید و در دسترس دیگران قرار ندهید.
قدم ۲: دریافت اطلاعات رقبا از Instagram API
حالا که به API دسترسی داریم، میتوانیم اطلاعات مربوط به فالوورها، تعاملات و پستهای رقبا را جمعآوری کنیم.
۲.۱ دریافت اطلاعات پروفایل رقبا
function getCompetitorProfile() {
var accessToken = "YOUR_ACCESS_TOKEN";
var competitorId = "COMPETITOR_USER_ID"; // ID پیج رقیب
var url = "https://graph.facebook.com/v17.0/" + competitorId + "?fields=username,followers_count,media_count&access_token=" + accessToken;
var response = UrlFetchApp.fetch(url);
var data = JSON.parse(response.getContentText());
Logger.log("Username: " + data.username);
Logger.log("Followers: " + data.followers_count);
Logger.log("Total Posts: " + data.media_count);
}
این اسکریپت اطلاعات پروفایل رقیب از جمله تعداد فالوورها و تعداد پستها را نمایش میدهد.
۲.۲ دریافت اطلاعات پستهای رقبا
function getCompetitorPosts() {
var accessToken = "YOUR_ACCESS_TOKEN";
var competitorId = "COMPETITOR_USER_ID";
var url = "https://graph.facebook.com/v17.0/" + competitorId + "/media?fields=id,caption,like_count,comments_count,timestamp&access_token=" + accessToken;
var response = UrlFetchApp.fetch(url);
var data = JSON.parse(response.getContentText()).data;
data.forEach(function(post) {
Logger.log("Post ID: " + post.id);
Logger.log("Caption: " + post.caption);
Logger.log("Likes: " + post.like_count);
Logger.log("Comments: " + post.comments_count);
Logger.log("Date: " + post.timestamp);
});
}
این کد، اطلاعات تمام پستهای رقیب از جمله تعداد لایک، کامنت و تاریخ انتشار را دریافت میکند.
قدم ۳: تحلیل دادههای رقبا
۳.۱ محاسبه میزان تعامل (Engagement Rate)
Engagement Rate یک معیار مهم است که نشان میدهد میزان تعامل کاربران با پستهای رقیب چقدر است.
فرمول تعامل:
function calculateEngagementRate(likes, comments, followers) {
return ((likes + comments) / followers) * 100;
}
با استفاده از این تابع میتوان تعامل هر پست را محاسبه کرد.
۳.۲ تحلیل بهترین زمان انتشار رقبا
میتوان بررسی کرد رقبا چه زمانی پست میگذارند و کدام زمانها بیشترین تعامل را دارند.
function analyzeBestPostingTime() {
var posts = getCompetitorPosts(); // دریافت اطلاعات پستها
var timeAnalysis = {};
posts.forEach(function(post) {
var hour = new Date(post.timestamp).getHours();
if (!timeAnalysis[hour]) timeAnalysis[hour] = { count: 0, engagement: 0 };
timeAnalysis[hour].count++;
timeAnalysis[hour].engagement += calculateEngagementRate(post.like_count, post.comments_count, 10000);
});
var bestHour = Object.keys(timeAnalysis).reduce((a, b) => timeAnalysis[a].engagement > timeAnalysis[b].engagement ? a : b);
Logger.log("Best Posting Time: " + bestHour + ":00");
}
این اسکریپت بررسی میکند که رقبا چه ساعتی بیشترین تعامل را داشتهاند.
قدم ۴: نمایش دادهها در Google Sheets
میتوان دادههای جمعآوری شده را در Google Sheets نمایش داد تا بهتر تحلیل کنیم.
function saveCompetitorDataToSheet() {
var sheet = SpreadsheetApp.getActiveSpreadsheet().getActiveSheet();
var competitorData = getCompetitorPosts();
sheet.clear();
sheet.appendRow(["Post ID", "Caption", "Likes", "Comments", "Engagement", "Timestamp"]);
competitorData.forEach(function(post) {
var engagement = calculateEngagementRate(post.like_count, post.comments_count, 10000);
sheet.appendRow([post.id, post.caption, post.like_count, post.comments_count, engagement, post.timestamp]);
});
Logger.log("Data saved successfully!");
}
این کد اطلاعات رقبا را در Google Sheets ذخیره میکند.
پیشنهاد میکنیم مقاله اتصال API اینستاگرام به Google Sheets برای مدیریت دادههای اینستاگرام را مطالعه کنید.
نتیجهگیری
ساخت ربات تحلیل رقبا با API اینستاگرام به ما این امکان را میدهد که:
دادههای رقبا را بهصورت خودکار دریافت کنیم.
بهترین زمان انتشار آنها را شناسایی کنیم.
میزان تعامل آنها را محاسبه کنیم.
استراتژیهای بازاریابی قویتری طراحی کنیم.
سوالات متداول
۱. آیا میتوان تمام پستهای یک رقیب را دریافت کرد؟
بله، اما فقط برای پیجهای بیزینسی و تأییدشده.
۲. آیا میتوان این دادهها را در داشبورد Power BI یا Google Data Studio نمایش داد؟
بله، میتوان Google Sheets را به این ابزارها متصل کرد.
۳. آیا API اینستاگرام رایگان است؟
بله، اما API اینستاگرام محدودیت درخواست روزانه دارد.