YouTube Video API — 데이터, 통계 & AI 감사 | YEB

동영상 정보, 댓글, 통계, 참여율 및 AI 기반 감사를 포함한 확장된 YouTube 동영상 데이터에 접근합니다. 개발자를 위한 종합 동영상 인텔리전스 툴킷.

무엇을 할 수 있나요?
상세한 동영상 데이터

제목, 설명, 게시일, 재생시간, 카테고리, 언어 등을 가져옵니다.

통계 및 참여도

조회수, 좋아요, 댓글 수를 조회하고 참여율을 계산합니다.

AI 기반 감사

동영상의 SEO와 참여도를 개선하기 위한 GPT 기반 제안을 받으세요.

라이브 테스트
99.9 % 가동 시간
59ms 응답
20 req/s
0.009 크레딧 / 요청

Basic Information


POST https://api.yeb.to/v1/youtube/video/information
매개변수유형필수설명
api_key string Your API key
video string Video ID (11 chars) **or** full YouTube URL

예시

curl -X POST https://api.yeb.to/v1/youtube/video/information \
  -H "Content-Type: application/json" \
  -d '{"api_key":"YOUR_KEY","video":"dQw4w9WgXcQ"}'

응답 예시

{
  "video": {
    "id":           "dQw4w9WgXcQ",
    "title":        "Rick Astley – Never Gonna Give You Up",
    "description":  "The official video for…",
    "duration":     "PT3M32S",
    "publishedAt":  "1987-10-25T00:00:00Z",
    "categoryId":   "10",
    "categoryName": "Music",
    "channelId":    "UCuAXFkgsw1L7xaCfnd5JJOw",
    "channelTitle": "Official Rick Astley",
    "statistics": {
      "viewCount":    "1 440 000 000",
      "likeCount":    "15 600 000",
      "commentCount": "1 900 000"
    },
    "thumbnails": { … },
    "contentDetails": { … },
    "snippet": { … }
  }
}
{"error":"Video not found","code":404}

응답 코드

코드설명
200 Success요청 처리 완료.
400 Bad Request입력 유효성 검사 실패.
401 UnauthorizedAPI 키 누락 또는 오류.
403 Forbidden키 비활성 또는 허용되지 않음.
429 Rate Limit요청이 너무 많습니다.
500 Server Error예기치 않은 오류.

Information

youtube/video/information 0.0090 credits

Parameters

API Key
body · string · required
Video
body · string · required

Code Samples


                
                
                
            

Response

Status:
Headers

                
Body

                

Video Tags


POST https://api.yeb.to/v1/youtube/video/tags
매개변수유형필수설명
api_key string Your API key
video string Video ID or URL

예시

curl -X POST https://api.yeb.to/v1/youtube/video/tags \
  -H "Content-Type: application/json" \
  -d '{"api_key":"YOUR_KEY","video":"dQw4w9WgXcQ"}'

응답 예시

{"tags":["80s","Rick Astley","Official Video"]}
{"error":"Tags unavailable","code":204}

응답 코드

코드설명
200 Success요청 처리 완료.
400 Bad Request입력 유효성 검사 실패.
401 UnauthorizedAPI 키 누락 또는 오류.
403 Forbidden키 비활성 또는 허용되지 않음.
429 Rate Limit요청이 너무 많습니다.
500 Server Error예기치 않은 오류.

Tags

youtube/video/tags 0.0030 credits

Parameters

API Key
body · string · required
Video
body · string · required

Code Samples


                
                
                
            

Response

Status:
Headers

                
Body

                

Top Comments


POST https://api.yeb.to/v1/youtube/video/comments
매개변수유형필수설명
api_key string Your API key
video string Video ID or URL
limit int 선택 1-100, default 50
order string 선택 relevance (default) | time
repliesOn bool 선택 true = include replies

예시

curl -X POST https://api.yeb.to/v1/youtube/video/comments \
  -H "Content-Type: application/json" \
  -d '{
    "api_key":   "YOUR_KEY",
    "video":     "dQw4w9WgXcQ",
    "limit":     25,
    "order":     "time",
    "repliesOn": true
  }'

응답 예시

{
  "cnt_comments": 25,
  "comments": [
    {
      "id":"Ugzx…",
      "author":"Alice",
      "text":"Still a banger!",
      "likes":42,
      "published":"2025-06-01T12:34:00Z",
      "replies":{
        "cnt":2,
        "items":[{"id":"Ugy…","author":"Bob","text":"100 %","likes":3,"published":"…"}]
      }
    }
  ]
}
{"error":"Comments disabled","code":403}

응답 코드

코드설명
200 Success요청 처리 완료.
400 Bad Request입력 유효성 검사 실패.
401 UnauthorizedAPI 키 누락 또는 오류.
403 Forbidden키 비활성 또는 허용되지 않음.
429 Rate Limit요청이 너무 많습니다.
500 Server Error예기치 않은 오류.

Comments

youtube/video/comments 0.0090 credits

Parameters

API Key
body · string · required
Video
body · string · required
Limit
body · string
Order
body · string
Include replies
body · string

Code Samples


                
                
                
            

Response

Status:
Headers

                
Body

                

Settings / Status


POST https://api.yeb.to/v1/youtube/video/settings
매개변수유형필수설명
api_key string Your API key
video string Video ID or URL

예시

curl -X POST https://api.yeb.to/v1/youtube/video/settings \
  -H "Content-Type: application/json" \
  -d '{"api_key":"YOUR_KEY","video":"dQw4w9WgXcQ"}'

응답 예시

{
   "settings": {
    "privacyStatus":       "public",
    "license":             "creativeCommon",
    "embeddable":          true,
       "publicStatsViewable": true,
   "disableComments":     false,
    "madeForKids":         false,
    "ageLimit":            false,
    "projection":          "rectangular",
   "recordingDate":       "2025-07-14",
    "locationDescription": "Berlin, Germany",

    "categoryId":          "25",
    "categoryName":        "News & Politics",
    "language":            "bg",
    "region":              "bg"
  }}
{"error":"Video not found","code":404}

응답 코드

코드설명
200 Success요청 처리 완료.
400 Bad Request입력 유효성 검사 실패.
401 UnauthorizedAPI 키 누락 또는 오류.
403 Forbidden키 비활성 또는 허용되지 않음.
429 Rate Limit요청이 너무 많습니다.
500 Server Error예기치 않은 오류.

Settings

youtube/video/settings 0.0040 credits

Parameters

API Key
body · string · required
Video
body · string · required

Code Samples


                
                
                
            

Response

Status:
Headers

                
Body

                

Restrictions


POST https://api.yeb.to/v1/youtube/video/restricted
매개변수유형필수설명
api_key string Your API key
video string Video ID or URL

예시

curl -X POST https://api.yeb.to/v1/youtube/video/restricted \
  -H "Content-Type: application/json" \
  -d '{"api_key":"YOUR_KEY","video":"dQw4w9WgXcQ"}'

응답 예시

{
    "restrictions": {
      "geoBlocked":    false,
      "ageRestricted": false,
      "blocked":       [],
      "allowed":       [],
      "embeddable":    true,
      "madeForKids":   false,
      "license":       "youtube",
      "privacyStatus": "public"
    }
  }
{"error":"Video removed","code":410}

응답 코드

코드설명
200 Success요청 처리 완료.
400 Bad Request입력 유효성 검사 실패.
401 UnauthorizedAPI 키 누락 또는 오류.
403 Forbidden키 비활성 또는 허용되지 않음.
429 Rate Limit요청이 너무 많습니다.
500 Server Error예기치 않은 오류.

Restrictions

youtube/video/restricted 0.0030 credits

Parameters

API Key
body · string · required
Video
body · string · required

Code Samples


                
                
                
            

Response

Status:
Headers

                
Body

                

Trending Check


POST https://api.yeb.to/v1/youtube/video/trending
매개변수유형필수설명
api_key string Your API key
video string Video ID or URL
country string 선택 ISO country (US default)
categoryId string 선택 Optional numeric ID

예시

curl -X POST https://api.yeb.to/v1/youtube/video/trending \
  -H "Content-Type: application/json" \
  -d '{"api_key":"YOUR_KEY","video":"dQw4w9WgXcQ","country":"GB"}'

응답 예시

{
    "trending": {
      "country":      "GB",
      "categoryId":   null,
      "categoryName": null,
      "isTrending":   true,
      "position":     17
    }
  }
{"error":"Quota exceeded","code":429}

응답 코드

코드설명
200 Success요청 처리 완료.
400 Bad Request입력 유효성 검사 실패.
401 UnauthorizedAPI 키 누락 또는 오류.
403 Forbidden키 비활성 또는 허용되지 않음.
429 Rate Limit요청이 너무 많습니다.
500 Server Error예기치 않은 오류.

Trending?

youtube/video/trending 0.0020 credits

Parameters

API Key
body · string · required
Video
body · string · required
Country
body · string
Category ID
body · string

Code Samples


                
                
                
            

Response

Status:
Headers

                
Body

                

Statistics


POST https://api.yeb.to/v1/youtube/video/statistics
매개변수유형필수설명
api_key string Your API key
video string Video ID or URL

예시

curl -X POST https://api.yeb.to/v1/youtube/video/statistics \
  -H "Content-Type: application/json" \
  -d '{"api_key":"YOUR_KEY","video":"dQw4w9WgXcQ"}'

응답 예시

{
  "statistics": {
    "views"      : 1580000000,
    "likes"      : 15400000,
    "comments"   : 1120000,
    "favourites" : 45000
  }
}
{"error":"Video not found","code":404}

응답 코드

코드설명
200 Success요청 처리 완료.
400 Bad Request입력 유효성 검사 실패.
401 UnauthorizedAPI 키 누락 또는 오류.
403 Forbidden키 비활성 또는 허용되지 않음.
429 Rate Limit요청이 너무 많습니다.
500 Server Error예기치 않은 오류.

Statistics

youtube/video/statistics 0.0040 credits

Parameters

API Key
body · string · required
Video
body · string · required

Code Samples


                
                
                
            

Response

Status:
Headers

                
Body

                

Watch-Time Estimate


POST https://api.yeb.to/v1/youtube/video/watchtime-estimate
매개변수유형필수설명
api_key string Your API key
video string Video ID or URL
avgRetention float 선택 Override (0-1). e.g. 0.55

예시

curl -X POST https://api.yeb.to/v1/youtube/video/watchtime-estimate \
  -H "Content-Type: application/json" \
  -d '{"api_key":"YOUR_KEY","video":"dQw4w9WgXcQ"}'

응답 예시

{
  "watchtime": {
    "views":        739,
    "durationSec":  1733,
    "avgRetention": 0.30,
    "perViewSec":   520,
    "seconds":      384206,
    "watchHours":   106.7

}
}
{"error":"Video not found","code":404}

응답 코드

코드설명
200 Success요청 처리 완료.
400 Bad Request입력 유효성 검사 실패.
401 UnauthorizedAPI 키 누락 또는 오류.
403 Forbidden키 비활성 또는 허용되지 않음.
429 Rate Limit요청이 너무 많습니다.
500 Server Error예기치 않은 오류.

Watch-Time

youtube/video/watchtime-estimate 0.0030 credits

Parameters

API Key
body · string · required
Video
body · string · required
Average Retention
body · string

Code Samples


                
                
                
            

Response

Status:
Headers

                
Body

                

Engagement Rate


POST https://api.yeb.to/v1/youtube/video/engagement-rate
매개변수유형필수설명
api_key string Your API key
video string Video ID or URL

예시

curl -X POST https://api.yeb.to/v1/youtube/video/engagement-rate \
  -H "Content-Type: application/json" \
  -d '{"api_key":"YOUR_KEY","video":"dQw4w9WgXcQ"}'

응답 예시

{
  "engagement": {
    "views":     1580000000,
    "likes":     15400000,
    "comments":  1120000,
    "rate":      0.011
  }
}
{"error":"Video not found","code":404}

응답 코드

코드설명
200 Success요청 처리 완료.
400 Bad Request입력 유효성 검사 실패.
401 UnauthorizedAPI 키 누락 또는 오류.
403 Forbidden키 비활성 또는 허용되지 않음.
429 Rate Limit요청이 너무 많습니다.
500 Server Error예기치 않은 오류.

Engagement

youtube/video/engagement-rate 0.0030 credits

Parameters

API Key
body · string · required
Video
body · string · required

Code Samples


                
                
                
            

Response

Status:
Headers

                
Body

                

Thumbnail URLs


POST https://api.yeb.to/v1/youtube/video/thumbnail
매개변수유형필수설명
api_key string Your API key
video string Video ID or URL

예시

curl -X POST https://api.yeb.to/v1/youtube/video/thumbnail \
  -H "Content-Type: application/json" \
  -d '{"api_key":"YOUR_KEY","video":"dQw4w9WgXcQ"}'

응답 예시

{
  "thumbnails": {
    "default":  "https://i.ytimg.com/vi/dQw4w9WgXcQ/default.jpg",
    "medium":   "https://i.ytimg.com/vi/dQw4w9WgXcQ/mqdefault.jpg",
    "high":     "https://i.ytimg.com/vi/dQw4w9WgXcQ/hqdefault.jpg",
    "standard": "https://i.ytimg.com/vi/dQw4w9WgXcQ/sddefault.jpg",
    "maxres":   "https://i.ytimg.com/vi/dQw4w9WgXcQ/maxresdefault.jpg"
  }
}
{"error":"Video not found","code":404}

응답 코드

코드설명
200 Success요청 처리 완료.
400 Bad Request입력 유효성 검사 실패.
401 UnauthorizedAPI 키 누락 또는 오류.
403 Forbidden키 비활성 또는 허용되지 않음.
429 Rate Limit요청이 너무 많습니다.
500 Server Error예기치 않은 오류.

Thumbnail URLs

youtube/video/thumbnail 0.0010 credits

Parameters

API Key
body · string · required
Video
body · string · required

Code Samples


                
                
                
            

Response

Status:
Headers

                
Body

                

Playlists Featuring This Video


POST https://api.yeb.to/v1/youtube/video/search-playlists
매개변수유형필수설명
api_key string Your API key
video string Video ID or URL
limit int 선택 1-50, default 50

예시

curl -X POST https://api.yeb.to/v1/youtube/video/search-playlists \
  -H "Content-Type: application/json" \
  -d '{"api_key":"YOUR_KEY","video":"dQw4w9WgXcQ","limit":10}'

응답 예시

{
  "cnt_playlists": 2,
  "playlists": [
    {"id":"PL123…","title":"Best 80s Hits","url":"https://…","found":true},
    {"id":"PL456…","title":"Rick Astley Favs","url":"https://…","found":true}
  ]
}
{"error":"Video not found","code":404}

응답 코드

코드설명
200 Success요청 처리 완료.
400 Bad Request입력 유효성 검사 실패.
401 UnauthorizedAPI 키 누락 또는 오류.
403 Forbidden키 비활성 또는 허용되지 않음.
429 Rate Limit요청이 너무 많습니다.
500 Server Error예기치 않은 오류.

Search Playlists

youtube/video/search-playlists 0.0100 credits

Parameters

API Key
body · string · required
Video
body · string · required
Limit
body · string

Code Samples


                
                
                
            

Response

Status:
Headers

                
Body

                

Extract Links


POST https://api.yeb.to/v1/youtube/video/extract-links
매개변수유형필수설명
api_key string Your API key
video string Video ID or URL

예시

curl -X POST https://api.yeb.to/v1/youtube/video/extract-links \
  -H "Content-Type: application/json" \
  -d '{"api_key":"YOUR_KEY","video":"dQw4w9WgXcQ"}'

응답 예시

응답 코드

코드설명
200 Success요청 처리 완료.
400 Bad Request입력 유효성 검사 실패.
401 UnauthorizedAPI 키 누락 또는 오류.
403 Forbidden키 비활성 또는 허용되지 않음.
429 Rate Limit요청이 너무 많습니다.
500 Server Error예기치 않은 오류.

Extract Links

youtube/video/extract-links 0.0020 credits

Parameters

API Key
body · string · required
Video
body · string · required

Code Samples


                
                
                
            

Response

Status:
Headers

                
Body

                

Extract Hashtags


POST https://api.yeb.to/v1/youtube/video/extract-hashtags
매개변수유형필수설명
api_key string Your API key
video string Video ID or URL

예시

curl -X POST https://api.yeb.to/v1/youtube/video/extract-hashtags \
  -H "Content-Type: application/json" \
  -d '{"api_key":"YOUR_KEY","video":"dQw4w9WgXcQ"}'

응답 예시

{"cnt_hashtags":2,"hashtags":["#RickAstley","#NeverGonnaGiveYouUp"]}
{"error":"Video not found","code":404}

응답 코드

코드설명
200 Success요청 처리 완료.
400 Bad Request입력 유효성 검사 실패.
401 UnauthorizedAPI 키 누락 또는 오류.
403 Forbidden키 비활성 또는 허용되지 않음.
429 Rate Limit요청이 너무 많습니다.
500 Server Error예기치 않은 오류.

Extract Hashtags

youtube/video/extract-hashtags 0.0050 credits

Parameters

API Key
body · string · required
Video
body · string · required

Code Samples


                
                
                
            

Response

Status:
Headers

                
Body

                

AI-Powered Audit


POST https://api.yeb.to/v1/youtube/video/audit
매개변수유형필수설명
api_key string Your API key
video string Video ID or URL
sample int 선택 Baseline sample size (10-100, default 50)

예시

curl -X POST https://api.yeb.to/v1/youtube/video/audit \
  -H "Content-Type: application/json" \
  -d '{"api_key":"YOUR_KEY","video":"dQw4w9WgXcQ"}'

응답 예시

{
  "videoId":"dQw4w9WgXcQ",
  "views":1580000000,
  "likes":15400000,
  "comments":1120000,
  "engagementRate":0.011,
  "channelMedianViews":420000,
  "isAboveMedian":true,
  "aiRecommendations":"• Use a more curiosity-driven title…"
}
{"error":"Video not found","code":404}

응답 코드

코드설명
200 Success요청 처리 완료.
400 Bad Request입력 유효성 검사 실패.
401 UnauthorizedAPI 키 누락 또는 오류.
403 Forbidden키 비활성 또는 허용되지 않음.
429 Rate Limit요청이 너무 많습니다.
500 Server Error예기치 않은 오류.

AI Audit

youtube/video/audit 0.0200 credits

Parameters

API Key
body · string · required
Video
body · string · required
Sample size
body · string

Code Samples


                
                
                
            

Response

Status:
Headers

                
Body

                

YouTube Video API — 데이터, 통계 & AI 감사 | YEB — Practical Guide

A hands-on guide to the YouTube Video API actions you’ll actually use: what each endpoint does, the problems it solves, the few parameters that matter, and how to read responses to build smarter UIs (mix builders, QA tools, SEO audits, and moderation dashboards).

#What this API solves

The youtube/video module turns a single YouTube video ID (or URL) into the practical signals you need: core metadata, engagement metrics, restrictions & status, comments, SEO surfaces (tags, hashtags, links), playlists featuring the video, and AI-powered audits. Use results to choose thumbnails/titles, estimate watch-time, detect country blocks, or group videos into mixes.

#Endpoints & when to use them

#POST /v1/youtube/video/information — Basic Information

  • Best for: Canonical data for cards, editors, and QA. Category & channel IDs for routing.
  • Output: video{ id, title, description, duration (ISO), publishedAt, categoryId + categoryName, channelId, channelTitle, statistics, thumbnails }.
  • Tip: Store id, channelId, categoryId as foreign keys; render duration as mm:ss.

#POST /v1/youtube/video/engagement-rate — Engagement Rate

  • Best for: Quick quality bar across uploads; ranking candidates for playlists.
  • Output: engagement{ views, likes, comments, rate } where rate = (likes+comments)/views.
  • Tip: Use buckets: <0.01 (weak), 0.01–0.03 (solid), >0.03 (hot) — tune per niche.

#POST /v1/youtube/video/comments — Top Comments

  • Best for: Social proof, snippets for landing pages, moderation/QA workflows.
  • Output: Flat list of top-level comments (optionally with replies).
  • Tip: For moderation UIs, request order="time"; for marketing, use relevance (default).

#POST /v1/youtube/video/restricted — Restrictions

  • Best for: Detecting geo blocks, age restrictions, and embeddability issues before publishing.
  • Output: restrictions{ geoBlocked, ageRestricted, blocked[], allowed[], embeddable, madeForKids, license, privacyStatus }.
  • Tip: If geoBlocked=true show “Unavailable in your region” and pick alternates for that market.

#POST /v1/youtube/video/settings — Settings / Status

  • Best for: Editorial checks: privacy, license, Made for Kids, projection, recordingDate, language/region.
  • Output: settings{ privacyStatus, license, embeddable, publicStatsViewable, disableComments, madeForKids, ageRestricted, projection, recordingDate, locationDescription, categoryId+Name, language, region }.
  • Tip: Use language/region to prefill translation tasks and subtitles pipelines.

#POST /v1/youtube/video/statistics — Statistics

  • Best for: Snapshot cards and simple leaderboards.
  • Output: statistics{ views, likes, comments, favourites } (point-in-time).

#POST /v1/youtube/video/tags — Video Tags

  • Best for: SEO diffing, tag normalization, clustering similar videos.
  • Output: tags[] or empty if unavailable.

#POST /v1/youtube/video/extract-hashtags — Extract Hashtags

  • Best for: Pulling visible #hashtags from title/description for social cross-posting.
  • Output: { cnt_hashtags, hashtags[] }.
  • Best for: Affiliate checks, out-link audits, or building a “Links” panel on video pages.
  • Output: { cnt_links, links[] }.

#POST /v1/youtube/video/thumbnail — Thumbnail URLs

  • Best for: Rendering cards without re-deriving thumb URLs.
  • Output: thumbnails{ default, medium, high, standard, maxres }.

#POST /v1/youtube/video/search-playlists — Playlists Featuring This Video

  • Best for: Discoverability & social proof (“featured in 12 playlists”).
  • Output: { cnt_playlists, playlists[{ id, title, url, found }] }.
  • Best for: Pinning “Now Trending in GB” badges and ordering on homepages.
  • Output: trending{ country, categoryId, categoryName, isTrending, position }.

#POST /v1/youtube/video/watchtime-estimate — Watch-Time Estimate

  • Best for: Forecasting watch-hours for mixes or promo decisions.
  • Output: watchtime{ views, durationSec, avgRetention, perViewSec, seconds, watchHours }.
  • Tip: Override avgRetention (0–1) if you know your niche average; otherwise we fallback by category.

#POST /v1/youtube/video/audit — AI-Powered Audit

  • Best for: Fast SEO/CTR feedback on title/description/tags vs channel baseline.
  • Output: audit{ videoId, views, likes, comments, engagementRate, channelMedianViews, isAboveMedian, aiRecommendations }.
  • Tip: Tune sample (10–100) to match channel cadence for meaningful medians.

#Quick start

# Basic info
curl -X POST "https://api.yeb.to/v1/youtube/video/information" \
  -H "Accept: application/json" -H "Content-Type: application/json" \
  -H "X-API-Key: <YOUR_API_KEY>" \
  -d '{ "video":"dQw4w9WgXcQ" }'
# Engagement rate
curl -X POST "https://api.yeb.to/v1/youtube/video/engagement-rate" \
  -H "Accept: application/json" -H "Content-Type: application/json" \
  -H "X-API-Key: <YOUR_API_KEY>" \
  -d '{ "video":"dQw4w9WgXcQ" }'
# Comments (latest 25, include replies)
curl -X POST "https://api.yeb.to/v1/youtube/video/comments" \
  -H "Accept: application/json" -H "Content-Type: application/json" \
  -H "X-API-Key: <YOUR_API_KEY>" \
  -d '{ "video":"dQw4w9WgXcQ", "limit":25, "order":"time", "repliesOn":true }'
# AI audit (use 50 last uploads as baseline)
curl -X POST "https://api.yeb.to/v1/youtube/video/audit" \
  -H "Accept: application/json" -H "Content-Type: application/json" \
  -H "X-API-Key: <YOUR_API_KEY>" \
  -d '{ "video":"dQw4w9WgXcQ", "sample":50 }'

#Parameters that actually matter

ParamTypeRequiredPractical guidance
api_key string Yes Your credential. Keep server-side or sign short-lived edge tokens.
video string Yes* 11-char ID or full URL. Not required for compare-videos (if available) or some meta actions.
order string No For comments: relevance (default) or time.
limit int No Comments/playlists page size. Reasonable 10–50; defaults provided per endpoint.
repliesOn bool No For comments, include reply threads when you need context.
country string No For trending check, ISO-3166 code (default US).
categoryId string|int No For trending check; use 10 for Music.
avgRetention float No For watchtime-estimate override (0–1). If omitted, we fall back to category averages.
sample int No For audit: channel baseline size (10–100, default 50) to compute median views.

#Reading & acting on responses

#Information — interpretation

{
  "video": {
    "id":"dQw4w9WgXcQ",
    "title":"Rick Astley – Never Gonna Give You Up",
    "duration":"PT3M32S",
    "publishedAt":"1987-10-25T00:00:00Z",
    "categoryId":"10",
    "categoryName":"Music",
    "channelId":"UCuAXFkgsw1L7xaCfnd5JJOw",
    "channelTitle":"Official Rick Astley"
  }
}
  • id — Video ID → watch URL, embeds, thumbnail derivation.
  • channelId — Use for deep links and channel-level rollups.
  • duration — ISO-8601; convert to mm:ss for chips (helpful in grid UIs).

#Engagement — interpretation

{ "engagement": { "views":1580000000, "likes":15400000, "comments":1120000, "rate":0.011 } }
  • Use case: Sort candidates for playlists by rate, then sanity-check with comments volume.

#Comments — interpretation

{
  "cnt_comments": 25,
  "comments": [
    { "id":"Ugz…", "author":"Alice", "text":"Still a banger!", "likes":42, "published":"2025-06-01T12:34:00Z",
      "replies": { "cnt":2, "items":[{"id":"Ugy…","author":"Bob","text":"100%","likes":3,"published":"…"}] } }
  ]
}
  • Surface: Show the first one or two “relevance” comments as social proof; switch to time for live streams.

#Restrictions — interpretation

{
  "restrictions": {
    "geoBlocked":false, "ageRestricted":false,
    "embeddable":true,  "privacyStatus":"public"
  }
}
  • Action: If embeddable=false, fallback to channel link instead of inline player.
{ "trending": { "country":"GB", "isTrending":true, "position":17 } }
  • Action: Add “Trending #17 in GB” badge; bump in country-specific rails.

#Watch-time estimate — interpretation

{
  "watchtime": {
    "views":739, "durationSec":1733,
    "avgRetention":0.30, "perViewSec":520,
    "seconds":384206, "watchHours":106.7
  }
}
  • Use case: Forecast weekly watch-hours; if below target, delay posting the next mix.

#Practical recipes

  • Playlist curation: Rank by engagement.rate, filter restrictions.embeddable=true, and ensure categoryId=10 for music.
  • SEO diff: Compare tags + hashtags against your top performers; feed weak items into /audit.
  • Compliance: Check restricted prior to embedding; show geo messages when geoBlocked.
  • Mix timing: Use watchtime.watchHours to decide whether to release or wait for the current video to peak.

#YouTube IDs you’ll work with

FieldWhat it isHow to use
id (Video ID) 11-char identifier Watch: https://www.youtube.com/watch?v={id} · Thumbs: https://i.ytimg.com/vi/{id}/hqdefault.jpg
channelId Channel identifier Channel: https://www.youtube.com/channel/{channelId}
playlistId Playlist identifier Playlist: https://www.youtube.com/playlist?list={playlistId}
commentId Comment identifier Moderation tools, permalinks, reply threading.
categoryId Numeric content category Common IDs below; 10 = Music

#Common YouTube Category IDs

IDCategory
1Film & Animation
2Autos & Vehicles
10Music
17Sports
20Gaming
22People & Blogs
23Comedy
24Entertainment
25News & Politics
26Howto & Style
27Education
28Science & Technology
29Nonprofits & Activism

#Errors & troubleshooting

  • 400 "Missing "action" parameter" — Provide one of the supported actions (see sections above).
  • 400 "Missing "video" parameter" — Supply ID or URL for video-based actions.
  • 404 "Video not found" — Invalid/removed/private video.
  • 403 "Comments disabled" — Respect channel/video settings; hide comment UI.
  • 429 "Quota exceeded" — Backoff and reduce polling; cache responses.

#API Changelog (youtube/video)

2026-03-07
Watch-time fields. Added perViewSec and watchHours to watchtime for easier planning.
2026-03-07
Engagement wrapper. Standardized engagement{ ... } payload in engagement-rate.
2026-03-07
Trending check. Response now includes categoryName (derived from categoryId).
2026-02-28
Comments API. Optional repliesOn flag now returns structured replies (replies{ cnt, items[] }).
2026-02-21
AI Audit. Baseline sampling (sample 10–100) and channel median comparison added; clearer aiRecommendations.
2026-02-14
Unified responses. Normalized keys across actions (e.g., thumbnails{}, statistics{}, restrictions{}).

Use the API Playgrounds below each section in this page to test requests with your own video IDs.

자주 묻는 질문

제목, 설명, 태그, 썸네일, 댓글(답글 포함), 통계(조회수, 좋아요, 댓글), 시청자 참여도, 동영상 챕터, 동영상이 포함된 재생목록, AI 기반 콘텐츠 감사까지 요청할 수 있습니다.

둘 다 지원됩니다! YouTube 동영상 ID(예: dQw4w9WgXcQ) 또는 전체 YouTube 동영상 URL을 전달할 수 있습니다.

API는 명확한 오류 메시지와 HTTP 상태 코드를 반환합니다(예: 404 찾을 수 없음, 403 제한/비공개 동영상).

예. 오류가 발생한 요청을 포함하여 모든 요청은 크레딧을 소비합니다. 크레딧은 성공 또는 실패와 관계없이 요청 수에 연결됩니다. 오류가 당사 플랫폼 문제로 인한 것이 분명한 경우 영향을 받은 크레딧을 복원합니다(현금 환불 없음).

[email protected]로 문의하세요. 피드백을 진지하게 받아들입니다—버그 리포트나 기능 요청이 의미 있는 경우 API를 빠르게 수정하거나 개선하고 감사의 표시로 50 무료 크레딧을 제공합니다.

API와 때로는 엔드포인트에 따라 다릅니다. 일부 엔드포인트는 외부 소스의 데이터를 사용하며 더 엄격한 제한이 있을 수 있습니다. 남용을 방지하고 플랫폼 안정성을 유지하기 위해 제한도 적용합니다. 각 엔드포인트의 구체적인 제한은 문서를 확인하세요.

크레딧 시스템으로 운영됩니다. 크레딧은 API 호출과 도구에 사용하는 선불, 환불 불가 단위입니다. 크레딧은 FIFO(오래된 것부터) 방식으로 소비되며 구매일로부터 12개월간 유효합니다. 대시보드에 각 구매 날짜와 만료일이 표시됩니다.

예. 구매한 모든 크레딧(소수 잔액 포함)은 구매일로부터 12개월간 유효합니다. 미사용 크레딧은 유효 기간 종료 시 자동으로 만료되어 영구 삭제됩니다. 만료된 크레딧은 복원하거나 현금 또는 기타 가치로 전환할 수 없습니다. 경과 규칙: 2025년 9월 22일 이전에 구매한 크레딧은 2025년 9월 22일에 구매한 것으로 처리되어 2026년 9월 22일에 만료됩니다(구매 시 더 이른 만료일이 명시되지 않은 한).

예—유효 기간 내에서 이월됩니다. 미사용 크레딧은 계속 사용 가능하며 구매 후 12개월 만료까지 매월 이월됩니다.

크레딧은 환불 불가입니다. 필요한 만큼만 구매하세요—나중에 언제든 충전할 수 있습니다. 플랫폼 오류로 인해 청구가 실패한 경우 조사 후 영향을 받은 크레딧을 복원할 수 있습니다. 현금 환불 없음.

가격은 달러가 아닌 크레딧으로 설정됩니다. 각 엔드포인트에는 자체 비용이 있습니다—위의 "크레딧 / 요청" 배지를 참조하세요. 항상 정확한 지출 금액을 알 수 있습니다.
← API로 돌아가기