%useLatestDescriptors
%use dataframe
This example uses the YouTube Data API: https://developers.google.com/youtube/v3/docs. Follow the tutorials over there to gain an API key.
val apiKey = System.getenv("YOUTUBE_API_KEY")
fun load(path: String): AnyRow = DataRow.read("https://www.googleapis.com/youtube/v3/$path&key=$apiKey")
fun load(path: String, maxPages: Int): AnyFrame {
val rows = mutableListOf<AnyRow>()
var pagePath = path
do {
val row = load(pagePath)
rows.add(row)
val next = row.getValueOrNull<String>("nextPageToken")
pagePath = path + "&pageToken=" + next
} while (next != null && rows.size < maxPages)
return rows.concat()
}
val df = load("search?q=cute%20cats&maxResults=50&part=snippet", 5)
df
kind | etag | nextPageToken | regionCode | pageInfo | items | prevPageToken | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
totalResults | resultsPerPage | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
youtube#searchListResponse | lQI5K5UKrmm76fx707npKC5qFrU | CDIQAA | AM | 1000000 | 50 | DataFrame [50 x 4]
... showing only top 5 of 50 rows | null | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
youtube#searchListResponse | qwjC2T9vq8UyDwk7952irKFfm0I | CGQQAA | AM | 1000000 | 50 | DataFrame [50 x 4]
... showing only top 5 of 50 rows | CDIQAQ | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
youtube#searchListResponse | FPoP9euk-Xm7rRl0vAORFzfCdWo | CJYBEAA | AM | 1000000 | 50 | DataFrame [50 x 4]
... showing only top 5 of 50 rows | CGQQAQ | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
youtube#searchListResponse | rvjtAtveus4RWPGoGSsiFFnxTjM | CMgBEAA | AM | 1000000 | 50 | DataFrame [50 x 4]
... showing only top 5 of 50 rows | CJYBEAE | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
youtube#searchListResponse | 2rKu0tyzN25dYGoKZvOAst135jY | CPoBEAA | AM | 1000000 | 50 | DataFrame [50 x 4]
... showing only top 5 of 50 rows | CMgBEAE |
val items = df.items.concat()
items
kind | etag | id | snippet | ||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
kind | videoId | publishedAt | channelId | title | description | thumbnails | channelTitle | liveBroadcastContent | publishTime | ||||||||||
default | medium | high | |||||||||||||||||
url | width | height | url | width | height | url | width | height | |||||||||||
youtube#searchResult | -4j4KnkCwLxhwCAhh8X8PfDhoK4 | youtube#video | y0sF5xhGreA | 2023-05-28T13:00:44Z | UCPIvT-zcQl2H0vabdXJGcpg | 20 Minutes of Adorable Kittens | B... | Cute, cuddly, and utterly chaotic! Th... | https://i.ytimg.com/vi/y0sF5xhGreA/de... | 120 | 90 | https://i.ytimg.com/vi/y0sF5xhGreA/mq... | 320 | 180 | https://i.ytimg.com/vi/y0sF5xhGreA/hq... | 480 | 360 | The Pet Collective | none | 2023-05-28T13:00:44Z |
youtube#searchResult | Zbg-j8TEKj_VvmRu2CHZgmZRkuw | youtube#video | 3bhkYoMWTFE | 2023-07-26T13:33:50Z | UCkMrzpvOdM2Ndc21jgbj8NA | Cats Doing Cat Things (3) | cat #cats #catlover #catvideos #catlo... | https://i.ytimg.com/vi/3bhkYoMWTFE/de... | 120 | 90 | https://i.ytimg.com/vi/3bhkYoMWTFE/mq... | 320 | 180 | https://i.ytimg.com/vi/3bhkYoMWTFE/hq... | 480 | 360 | catvid-19 | none | 2023-07-26T13:33:50Z |
youtube#searchResult | XHnuMJew3mj2vm_OE5-vMOVEl_M | youtube#video | NsMKvVdEPkw | 2023-05-06T14:18:05Z | UCDbVjtCeUnZliM4wTkhq2Lg | Kitten meowing to attract cats | cat meowing to attract cats,cats meow... | https://i.ytimg.com/vi/NsMKvVdEPkw/de... | 120 | 90 | https://i.ytimg.com/vi/NsMKvVdEPkw/mq... | 320 | 180 | https://i.ytimg.com/vi/NsMKvVdEPkw/hq... | 480 | 360 | Cute Baby Cats 267 | none | 2023-05-06T14:18:05Z |
youtube#searchResult | TkqVE28uNUVg47C4mRkfqER1ZM8 | youtube#video | wdjpworLSk8 | 2023-09-15T22:02:00Z | UCQQcnrcfQbWvCl2lBvF5hoQ | Cute kittens❤️【30】#shorts #cutecat520... | shorts #catvideos #cat #funnycats #ki... | https://i.ytimg.com/vi/wdjpworLSk8/de... | 120 | 90 | https://i.ytimg.com/vi/wdjpworLSk8/mq... | 320 | 180 | https://i.ytimg.com/vi/wdjpworLSk8/hq... | 480 | 360 | Cute Cat | none | 2023-09-15T22:02:00Z |
youtube#searchResult | G1S5_A7vd2ZXZf9RQRWdRghk-TM | youtube#video | NlxYY7w1UGU | 2024-01-08T13:13:21Z | UCTmml_z2rBmxDUA9Ie4o_uA | Cat videos cute cats kittens | cat #cats #cute #funnycat #funnycats ... | https://i.ytimg.com/vi/NlxYY7w1UGU/de... | 120 | 90 | https://i.ytimg.com/vi/NlxYY7w1UGU/mq... | 320 | 180 | https://i.ytimg.com/vi/NlxYY7w1UGU/hq... | 480 | 360 | Little Kitten 21 | none | 2024-01-08T13:13:21Z |
youtube#searchResult | Ai7hOgkIKMs07ZGH8GsJDUNhS84 | youtube#video | 0KJS_2d2jOk | 2024-08-23T23:46:27Z | UCXGm1fhynaYAFwaOxBSTPNg | 13❤Cute kitten #cat #lovecats #ca... | Cute kitten #cat #lovecats #cats #cat... | https://i.ytimg.com/vi/0KJS_2d2jOk/de... | 120 | 90 | https://i.ytimg.com/vi/0KJS_2d2jOk/mq... | 320 | 180 | https://i.ytimg.com/vi/0KJS_2d2jOk/hq... | 480 | 360 | Cat Kitten | none | 2024-08-23T23:46:27Z |
youtube#searchResult | ieJNpaTNwWAVrRZTyXdyX_5taiw | youtube#video | DrpvkCRE2P4 | 2023-05-25T10:30:02Z | UCO5aEyYJeUXv8rxQEvbUMeA | Cute baby kitten sound ❤️ #shorts | https://i.ytimg.com/vi/DrpvkCRE2P4/de... | 120 | 90 | https://i.ytimg.com/vi/DrpvkCRE2P4/mq... | 320 | 180 | https://i.ytimg.com/vi/DrpvkCRE2P4/hq... | 480 | 360 | Lovely Kittens | none | 2023-05-25T10:30:02Z | |
youtube#searchResult | vJrK4uS3IGqoI0fM65bSEhFqUe8 | youtube#video | a7K-kWT_C2A | 2023-07-22T05:27:58Z | UCsVD3ZguqePDEKaPHUeaIuQ | Funny Cute Cats | https://i.ytimg.com/vi/a7K-kWT_C2A/de... | 120 | 90 | https://i.ytimg.com/vi/a7K-kWT_C2A/mq... | 320 | 180 | https://i.ytimg.com/vi/a7K-kWT_C2A/hq... | 480 | 360 | ThomasTrucker | none | 2023-07-22T05:27:58Z | |
youtube#searchResult | U4EBCE6U_LhzutW4RdWfrQG96l8 | youtube#video | 28O4PxyCG9E | 2023-12-25T07:55:44Z | UCRSLeYO3BOhRAYz0vLfVSWw | My Kitten's Name Reveal! #cat #cu... | My Kitten's Name Reveal! #cat #cute #... | https://i.ytimg.com/vi/28O4PxyCG9E/de... | 120 | 90 | https://i.ytimg.com/vi/28O4PxyCG9E/mq... | 320 | 180 | https://i.ytimg.com/vi/28O4PxyCG9E/hq... | 480 | 360 | SugarStar | none | 2023-12-25T07:55:44Z |
youtube#searchResult | QguIS2YsmSAZaB-Rahf0eJG6mGo | youtube#video | MlDtL2hIj-Q | 2023-11-19T19:00:10Z | UCPIvT-zcQl2H0vabdXJGcpg | 30 Minutes of the Worlds CUTEST Kitte... | How cute are these kittens!!! ☺️ ✨ ... | https://i.ytimg.com/vi/MlDtL2hIj-Q/de... | 120 | 90 | https://i.ytimg.com/vi/MlDtL2hIj-Q/mq... | 320 | 180 | https://i.ytimg.com/vi/MlDtL2hIj-Q/hq... | 480 | 360 | The Pet Collective | none | 2023-11-19T19:00:10Z |
youtube#searchResult | 13rrjHLEedgFgBm9W24i_MYXOAQ | youtube#video | cytJLvf-eVs | 2020-02-05T15:49:45Z | UC8hC-augAnujJeprhjI0YkA | Baby Cats - Cute and Funny Cat Videos... | Watching funny baby cats is the harde... | https://i.ytimg.com/vi/cytJLvf-eVs/de... | 120 | 90 | https://i.ytimg.com/vi/cytJLvf-eVs/mq... | 320 | 180 | https://i.ytimg.com/vi/cytJLvf-eVs/hq... | 480 | 360 | Aww Animals | none | 2020-02-05T15:49:45Z |
youtube#searchResult | r1I6XnLSUeEactrrJR4BMdd57m4 | youtube#video | afm0c53xO2o | 2024-06-26T17:41:01Z | UCI7EM9d6P4wRWRjbFXcxUlQ | Kitten Arrival! #CatLovers #CuteCats ... | https://i.ytimg.com/vi/afm0c53xO2o/de... | 120 | 90 | https://i.ytimg.com/vi/afm0c53xO2o/mq... | 320 | 180 | https://i.ytimg.com/vi/afm0c53xO2o/hq... | 480 | 360 | susan chan | none | 2024-06-26T17:41:01Z | |
youtube#searchResult | rK8Qc4ihCS324kjmEXvkbO4Q3js | youtube#video | ASFCURj-2hQ | 2024-09-26T03:51:17Z | UCntAD-sZOPUXRIcw9syL-MQ | Cat & cute baby laughing vi... | Cat & cute baby laughing video #funny... | https://i.ytimg.com/vi/ASFCURj-2hQ/de... | 120 | 90 | https://i.ytimg.com/vi/ASFCURj-2hQ/mq... | 320 | 180 | https://i.ytimg.com/vi/ASFCURj-2hQ/hq... | 480 | 360 | Toon4 | none | 2024-09-26T03:51:17Z |
youtube#searchResult | eRGtBGQW7bQjHH4WIr_I0NYD6wU | youtube#video | Po098TRdOn4 | 2023-01-02T09:46:11Z | UC6OZkZ7VcRGNMV1uQwnt9Gg | Funny cat videos | cute cats | Try... | Funny cat videos | cute cats | Try no... | https://i.ytimg.com/vi/Po098TRdOn4/de... | 120 | 90 | https://i.ytimg.com/vi/Po098TRdOn4/mq... | 320 | 180 | https://i.ytimg.com/vi/Po098TRdOn4/hq... | 480 | 360 | SRH Funny cats | none | 2023-01-02T09:46:11Z |
youtube#searchResult | 2msQkphBRNHn94rAJvYE8FVuZdU | youtube#video | 3AfETaI8Ias | 2023-02-21T18:58:48Z | UCS56r87Y7q1SrAB-42brE-w | Kisa ❤️ #cat #cats | https://i.ytimg.com/vi/3AfETaI8Ias/de... | 120 | 90 | https://i.ytimg.com/vi/3AfETaI8Ias/mq... | 320 | 180 | https://i.ytimg.com/vi/3AfETaI8Ias/hq... | 480 | 360 | Sonyakisa8 TT | none | 2023-02-21T18:58:48Z | |
youtube#searchResult | q8e9w3IMSVK8TbQMWejsG2yF-4M | youtube#video | 0AwB4ivE-Uw | 2024-10-18T01:33:00Z | UC0HRkOUeR4l1qwpRf9gLmdA | Cute cats and monkey take my birthday... | https://i.ytimg.com/vi/0AwB4ivE-Uw/de... | 120 | 90 | https://i.ytimg.com/vi/0AwB4ivE-Uw/mq... | 320 | 180 | https://i.ytimg.com/vi/0AwB4ivE-Uw/hq... | 480 | 360 | Lovie Jennaira | none | 2024-10-18T01:33:00Z | |
youtube#searchResult | t1vv105IWNG2EOHsMAK2yRtj010 | youtube#video | tpiyEe_CqB4 | 2020-04-10T16:00:28Z | UCzn2gx8zzhF0A4Utk8TEDNQ | Cute and Funny Cat Videos to Keep You... | Hoomans! Rufus here! Cats are my best... | https://i.ytimg.com/vi/tpiyEe_CqB4/de... | 120 | 90 | https://i.ytimg.com/vi/tpiyEe_CqB4/mq... | 320 | 180 | https://i.ytimg.com/vi/tpiyEe_CqB4/hq... | 480 | 360 | Rufus | none | 2020-04-10T16:00:28Z |
youtube#searchResult | _glv5BdVzpz4RQZ8R_82HyJW_DM | youtube#video | adbGYRuZ5OQ | 2024-09-06T09:21:51Z | UCKCc6gU1ZMSVtsewQ4GaczQ | #cutecats #miaw #miawmiaw #miau #baby... | https://i.ytimg.com/vi/adbGYRuZ5OQ/de... | 120 | 90 | https://i.ytimg.com/vi/adbGYRuZ5OQ/mq... | 320 | 180 | https://i.ytimg.com/vi/adbGYRuZ5OQ/hq... | 480 | 360 | DIARY DIMURA | none | 2024-09-06T09:21:51Z | |
youtube#searchResult | 3FMsKvZ4tnjiAOCqvXQe8JdAtQw | youtube#video | 2M1AFRWPpy8 | 2024-06-27T12:23:24Z | UC0HRkOUeR4l1qwpRf9gLmdA | Cute cats and kittens steals my kinde... | https://i.ytimg.com/vi/2M1AFRWPpy8/de... | 120 | 90 | https://i.ytimg.com/vi/2M1AFRWPpy8/mq... | 320 | 180 | https://i.ytimg.com/vi/2M1AFRWPpy8/hq... | 480 | 360 | Lovie Jennaira | none | 2024-06-27T12:23:24Z | |
youtube#searchResult | ITgG4oyI_IJMEeX54uhSWZSQT28 | youtube#video | DiEJQ3ZgQvI | 2024-10-13T08:18:58Z | UCI3-YbYcx-rfnQjwU9P9fwg | Cute Kitten of Cat is doing Makeup fo... | cats #cutecat #catvideos #cute #kitte... | https://i.ytimg.com/vi/DiEJQ3ZgQvI/de... | 120 | 90 | https://i.ytimg.com/vi/DiEJQ3ZgQvI/mq... | 320 | 180 | https://i.ytimg.com/vi/DiEJQ3ZgQvI/hq... | 480 | 360 | Lovento Films | none | 2024-10-13T08:18:58Z |
val videos = items.dropNulls { id.videoId }
.select { id.videoId named "id" and snippet }
.distinct()
videos
id | snippet | |||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
publishedAt | channelId | title | description | thumbnails | channelTitle | liveBroadcastContent | publishTime | |||||||||
default | medium | high | ||||||||||||||
url | width | height | url | width | height | url | width | height | ||||||||
y0sF5xhGreA | 2023-05-28T13:00:44Z | UCPIvT-zcQl2H0vabdXJGcpg | 20 Minutes of Adorable Kittens | B... | Cute, cuddly, and utterly chaotic! Th... | https://i.ytimg.com/vi/y0sF5xhGreA/de... | 120 | 90 | https://i.ytimg.com/vi/y0sF5xhGreA/mq... | 320 | 180 | https://i.ytimg.com/vi/y0sF5xhGreA/hq... | 480 | 360 | The Pet Collective | none | 2023-05-28T13:00:44Z |
3bhkYoMWTFE | 2023-07-26T13:33:50Z | UCkMrzpvOdM2Ndc21jgbj8NA | Cats Doing Cat Things (3) | cat #cats #catlover #catvideos #catlo... | https://i.ytimg.com/vi/3bhkYoMWTFE/de... | 120 | 90 | https://i.ytimg.com/vi/3bhkYoMWTFE/mq... | 320 | 180 | https://i.ytimg.com/vi/3bhkYoMWTFE/hq... | 480 | 360 | catvid-19 | none | 2023-07-26T13:33:50Z |
NsMKvVdEPkw | 2023-05-06T14:18:05Z | UCDbVjtCeUnZliM4wTkhq2Lg | Kitten meowing to attract cats | cat meowing to attract cats,cats meow... | https://i.ytimg.com/vi/NsMKvVdEPkw/de... | 120 | 90 | https://i.ytimg.com/vi/NsMKvVdEPkw/mq... | 320 | 180 | https://i.ytimg.com/vi/NsMKvVdEPkw/hq... | 480 | 360 | Cute Baby Cats 267 | none | 2023-05-06T14:18:05Z |
wdjpworLSk8 | 2023-09-15T22:02:00Z | UCQQcnrcfQbWvCl2lBvF5hoQ | Cute kittens❤️【30】#shorts #cutecat520... | shorts #catvideos #cat #funnycats #ki... | https://i.ytimg.com/vi/wdjpworLSk8/de... | 120 | 90 | https://i.ytimg.com/vi/wdjpworLSk8/mq... | 320 | 180 | https://i.ytimg.com/vi/wdjpworLSk8/hq... | 480 | 360 | Cute Cat | none | 2023-09-15T22:02:00Z |
NlxYY7w1UGU | 2024-01-08T13:13:21Z | UCTmml_z2rBmxDUA9Ie4o_uA | Cat videos cute cats kittens | cat #cats #cute #funnycat #funnycats ... | https://i.ytimg.com/vi/NlxYY7w1UGU/de... | 120 | 90 | https://i.ytimg.com/vi/NlxYY7w1UGU/mq... | 320 | 180 | https://i.ytimg.com/vi/NlxYY7w1UGU/hq... | 480 | 360 | Little Kitten 21 | none | 2024-01-08T13:13:21Z |
0KJS_2d2jOk | 2024-08-23T23:46:27Z | UCXGm1fhynaYAFwaOxBSTPNg | 13❤Cute kitten #cat #lovecats #ca... | Cute kitten #cat #lovecats #cats #cat... | https://i.ytimg.com/vi/0KJS_2d2jOk/de... | 120 | 90 | https://i.ytimg.com/vi/0KJS_2d2jOk/mq... | 320 | 180 | https://i.ytimg.com/vi/0KJS_2d2jOk/hq... | 480 | 360 | Cat Kitten | none | 2024-08-23T23:46:27Z |
DrpvkCRE2P4 | 2023-05-25T10:30:02Z | UCO5aEyYJeUXv8rxQEvbUMeA | Cute baby kitten sound ❤️ #shorts | https://i.ytimg.com/vi/DrpvkCRE2P4/de... | 120 | 90 | https://i.ytimg.com/vi/DrpvkCRE2P4/mq... | 320 | 180 | https://i.ytimg.com/vi/DrpvkCRE2P4/hq... | 480 | 360 | Lovely Kittens | none | 2023-05-25T10:30:02Z | |
a7K-kWT_C2A | 2023-07-22T05:27:58Z | UCsVD3ZguqePDEKaPHUeaIuQ | Funny Cute Cats | https://i.ytimg.com/vi/a7K-kWT_C2A/de... | 120 | 90 | https://i.ytimg.com/vi/a7K-kWT_C2A/mq... | 320 | 180 | https://i.ytimg.com/vi/a7K-kWT_C2A/hq... | 480 | 360 | ThomasTrucker | none | 2023-07-22T05:27:58Z | |
28O4PxyCG9E | 2023-12-25T07:55:44Z | UCRSLeYO3BOhRAYz0vLfVSWw | My Kitten's Name Reveal! #cat #cu... | My Kitten's Name Reveal! #cat #cute #... | https://i.ytimg.com/vi/28O4PxyCG9E/de... | 120 | 90 | https://i.ytimg.com/vi/28O4PxyCG9E/mq... | 320 | 180 | https://i.ytimg.com/vi/28O4PxyCG9E/hq... | 480 | 360 | SugarStar | none | 2023-12-25T07:55:44Z |
MlDtL2hIj-Q | 2023-11-19T19:00:10Z | UCPIvT-zcQl2H0vabdXJGcpg | 30 Minutes of the Worlds CUTEST Kitte... | How cute are these kittens!!! ☺️ ✨ ... | https://i.ytimg.com/vi/MlDtL2hIj-Q/de... | 120 | 90 | https://i.ytimg.com/vi/MlDtL2hIj-Q/mq... | 320 | 180 | https://i.ytimg.com/vi/MlDtL2hIj-Q/hq... | 480 | 360 | The Pet Collective | none | 2023-11-19T19:00:10Z |
cytJLvf-eVs | 2020-02-05T15:49:45Z | UC8hC-augAnujJeprhjI0YkA | Baby Cats - Cute and Funny Cat Videos... | Watching funny baby cats is the harde... | https://i.ytimg.com/vi/cytJLvf-eVs/de... | 120 | 90 | https://i.ytimg.com/vi/cytJLvf-eVs/mq... | 320 | 180 | https://i.ytimg.com/vi/cytJLvf-eVs/hq... | 480 | 360 | Aww Animals | none | 2020-02-05T15:49:45Z |
afm0c53xO2o | 2024-06-26T17:41:01Z | UCI7EM9d6P4wRWRjbFXcxUlQ | Kitten Arrival! #CatLovers #CuteCats ... | https://i.ytimg.com/vi/afm0c53xO2o/de... | 120 | 90 | https://i.ytimg.com/vi/afm0c53xO2o/mq... | 320 | 180 | https://i.ytimg.com/vi/afm0c53xO2o/hq... | 480 | 360 | susan chan | none | 2024-06-26T17:41:01Z | |
ASFCURj-2hQ | 2024-09-26T03:51:17Z | UCntAD-sZOPUXRIcw9syL-MQ | Cat & cute baby laughing vi... | Cat & cute baby laughing video #funny... | https://i.ytimg.com/vi/ASFCURj-2hQ/de... | 120 | 90 | https://i.ytimg.com/vi/ASFCURj-2hQ/mq... | 320 | 180 | https://i.ytimg.com/vi/ASFCURj-2hQ/hq... | 480 | 360 | Toon4 | none | 2024-09-26T03:51:17Z |
Po098TRdOn4 | 2023-01-02T09:46:11Z | UC6OZkZ7VcRGNMV1uQwnt9Gg | Funny cat videos | cute cats | Try... | Funny cat videos | cute cats | Try no... | https://i.ytimg.com/vi/Po098TRdOn4/de... | 120 | 90 | https://i.ytimg.com/vi/Po098TRdOn4/mq... | 320 | 180 | https://i.ytimg.com/vi/Po098TRdOn4/hq... | 480 | 360 | SRH Funny cats | none | 2023-01-02T09:46:11Z |
3AfETaI8Ias | 2023-02-21T18:58:48Z | UCS56r87Y7q1SrAB-42brE-w | Kisa ❤️ #cat #cats | https://i.ytimg.com/vi/3AfETaI8Ias/de... | 120 | 90 | https://i.ytimg.com/vi/3AfETaI8Ias/mq... | 320 | 180 | https://i.ytimg.com/vi/3AfETaI8Ias/hq... | 480 | 360 | Sonyakisa8 TT | none | 2023-02-21T18:58:48Z | |
0AwB4ivE-Uw | 2024-10-18T01:33:00Z | UC0HRkOUeR4l1qwpRf9gLmdA | Cute cats and monkey take my birthday... | https://i.ytimg.com/vi/0AwB4ivE-Uw/de... | 120 | 90 | https://i.ytimg.com/vi/0AwB4ivE-Uw/mq... | 320 | 180 | https://i.ytimg.com/vi/0AwB4ivE-Uw/hq... | 480 | 360 | Lovie Jennaira | none | 2024-10-18T01:33:00Z | |
tpiyEe_CqB4 | 2020-04-10T16:00:28Z | UCzn2gx8zzhF0A4Utk8TEDNQ | Cute and Funny Cat Videos to Keep You... | Hoomans! Rufus here! Cats are my best... | https://i.ytimg.com/vi/tpiyEe_CqB4/de... | 120 | 90 | https://i.ytimg.com/vi/tpiyEe_CqB4/mq... | 320 | 180 | https://i.ytimg.com/vi/tpiyEe_CqB4/hq... | 480 | 360 | Rufus | none | 2020-04-10T16:00:28Z |
adbGYRuZ5OQ | 2024-09-06T09:21:51Z | UCKCc6gU1ZMSVtsewQ4GaczQ | #cutecats #miaw #miawmiaw #miau #baby... | https://i.ytimg.com/vi/adbGYRuZ5OQ/de... | 120 | 90 | https://i.ytimg.com/vi/adbGYRuZ5OQ/mq... | 320 | 180 | https://i.ytimg.com/vi/adbGYRuZ5OQ/hq... | 480 | 360 | DIARY DIMURA | none | 2024-09-06T09:21:51Z | |
2M1AFRWPpy8 | 2024-06-27T12:23:24Z | UC0HRkOUeR4l1qwpRf9gLmdA | Cute cats and kittens steals my kinde... | https://i.ytimg.com/vi/2M1AFRWPpy8/de... | 120 | 90 | https://i.ytimg.com/vi/2M1AFRWPpy8/mq... | 320 | 180 | https://i.ytimg.com/vi/2M1AFRWPpy8/hq... | 480 | 360 | Lovie Jennaira | none | 2024-06-27T12:23:24Z | |
DiEJQ3ZgQvI | 2024-10-13T08:18:58Z | UCI3-YbYcx-rfnQjwU9P9fwg | Cute Kitten of Cat is doing Makeup fo... | cats #cutecat #catvideos #cute #kitte... | https://i.ytimg.com/vi/DiEJQ3ZgQvI/de... | 120 | 90 | https://i.ytimg.com/vi/DiEJQ3ZgQvI/mq... | 320 | 180 | https://i.ytimg.com/vi/DiEJQ3ZgQvI/hq... | 480 | 360 | Lovento Films | none | 2024-10-13T08:18:58Z |
val parsed = videos.parse()
val loaded = parsed.convert { colsAtAnyDepth().colsOf<URL>() }.with { IMG(it, maxHeight = 150) }
.add("video") { IFRAME("https://www.youtube.com/embed/$id") }
NOTE: For this example, the DataFrame needs to be rendered as HTML. This means that when running in Kotlin Notebook, "Render DataFrame tables natively" needs to be turned off.
val clean = loaded.move { snippet.channelId and snippet.channelTitle }.under("channel")
.move { snippet.title and snippet.publishedAt }.toTop()
.remove { snippet }
clean
id | title | publishedAt | channel | video | |
---|---|---|---|---|---|
channelId | channelTitle | ||||
y0sF5xhGreA | 20 Minutes of Adorable Kittens | B... | 2023-05-28T13:00:44Z | UCPIvT-zcQl2H0vabdXJGcpg | The Pet Collective | <iframe src="https://www.youtube.com/... |
3bhkYoMWTFE | Cats Doing Cat Things (3) | 2023-07-26T13:33:50Z | UCkMrzpvOdM2Ndc21jgbj8NA | catvid-19 | <iframe src="https://www.youtube.com/... |
NsMKvVdEPkw | Kitten meowing to attract cats | 2023-05-06T14:18:05Z | UCDbVjtCeUnZliM4wTkhq2Lg | Cute Baby Cats 267 | <iframe src="https://www.youtube.com/... |
wdjpworLSk8 | Cute kittens❤️【30】#shorts #cutecat520... | 2023-09-15T22:02:00Z | UCQQcnrcfQbWvCl2lBvF5hoQ | Cute Cat | <iframe src="https://www.youtube.com/... |
NlxYY7w1UGU | Cat videos cute cats kittens | 2024-01-08T13:13:21Z | UCTmml_z2rBmxDUA9Ie4o_uA | Little Kitten 21 | <iframe src="https://www.youtube.com/... |
0KJS_2d2jOk | 13❤Cute kitten #cat #lovecats #ca... | 2024-08-23T23:46:27Z | UCXGm1fhynaYAFwaOxBSTPNg | Cat Kitten | <iframe src="https://www.youtube.com/... |
DrpvkCRE2P4 | Cute baby kitten sound ❤️ #shorts | 2023-05-25T10:30:02Z | UCO5aEyYJeUXv8rxQEvbUMeA | Lovely Kittens | <iframe src="https://www.youtube.com/... |
a7K-kWT_C2A | Funny Cute Cats | 2023-07-22T05:27:58Z | UCsVD3ZguqePDEKaPHUeaIuQ | ThomasTrucker | <iframe src="https://www.youtube.com/... |
28O4PxyCG9E | My Kitten's Name Reveal! #cat #cu... | 2023-12-25T07:55:44Z | UCRSLeYO3BOhRAYz0vLfVSWw | SugarStar | <iframe src="https://www.youtube.com/... |
MlDtL2hIj-Q | 30 Minutes of the Worlds CUTEST Kitte... | 2023-11-19T19:00:10Z | UCPIvT-zcQl2H0vabdXJGcpg | The Pet Collective | <iframe src="https://www.youtube.com/... |
cytJLvf-eVs | Baby Cats - Cute and Funny Cat Videos... | 2020-02-05T15:49:45Z | UC8hC-augAnujJeprhjI0YkA | Aww Animals | <iframe src="https://www.youtube.com/... |
afm0c53xO2o | Kitten Arrival! #CatLovers #CuteCats ... | 2024-06-26T17:41:01Z | UCI7EM9d6P4wRWRjbFXcxUlQ | susan chan | <iframe src="https://www.youtube.com/... |
ASFCURj-2hQ | Cat & cute baby laughing vi... | 2024-09-26T03:51:17Z | UCntAD-sZOPUXRIcw9syL-MQ | Toon4 | <iframe src="https://www.youtube.com/... |
Po098TRdOn4 | Funny cat videos | cute cats | Try... | 2023-01-02T09:46:11Z | UC6OZkZ7VcRGNMV1uQwnt9Gg | SRH Funny cats | <iframe src="https://www.youtube.com/... |
3AfETaI8Ias | Kisa ❤️ #cat #cats | 2023-02-21T18:58:48Z | UCS56r87Y7q1SrAB-42brE-w | Sonyakisa8 TT | <iframe src="https://www.youtube.com/... |
0AwB4ivE-Uw | Cute cats and monkey take my birthday... | 2024-10-18T01:33:00Z | UC0HRkOUeR4l1qwpRf9gLmdA | Lovie Jennaira | <iframe src="https://www.youtube.com/... |
tpiyEe_CqB4 | Cute and Funny Cat Videos to Keep You... | 2020-04-10T16:00:28Z | UCzn2gx8zzhF0A4Utk8TEDNQ | Rufus | <iframe src="https://www.youtube.com/... |
adbGYRuZ5OQ | #cutecats #miaw #miawmiaw #miau #baby... | 2024-09-06T09:21:51Z | UCKCc6gU1ZMSVtsewQ4GaczQ | DIARY DIMURA | <iframe src="https://www.youtube.com/... |
2M1AFRWPpy8 | Cute cats and kittens steals my kinde... | 2024-06-27T12:23:24Z | UC0HRkOUeR4l1qwpRf9gLmdA | Lovie Jennaira | <iframe src="https://www.youtube.com/... |
DiEJQ3ZgQvI | Cute Kitten of Cat is doing Makeup fo... | 2024-10-13T08:18:58Z | UCI3-YbYcx-rfnQjwU9P9fwg | Lovento Films | <iframe src="https://www.youtube.com/... |
val statPages = clean.id.chunked(50).map {
val ids = it.joinToString("%2C")
load("videos?part=statistics&id=$ids")
}
statPages
id | |||||||||||||||||||||||||||||||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
kind | etag | items | pageInfo | ||||||||||||||||||||||||||||||||||||||||||||||||||
totalResults | resultsPerPage | ||||||||||||||||||||||||||||||||||||||||||||||||||||
youtube#videoListResponse | wPxhiujCRv1kXPzOQWnlvEr9S1Q | DataFrame [50 x 4]
... showing only top 5 of 50 rows | 50 | 50 | |||||||||||||||||||||||||||||||||||||||||||||||||
youtube#videoListResponse | wQoUtqpTweWEUOmeT9IoqhqDicA | DataFrame [50 x 4]
... showing only top 5 of 50 rows | 50 | 50 | |||||||||||||||||||||||||||||||||||||||||||||||||
youtube#videoListResponse | bReEOaN_HaF-6DqwQwinuV9rYUM | DataFrame [50 x 4]
... showing only top 5 of 50 rows | 50 | 50 | |||||||||||||||||||||||||||||||||||||||||||||||||
youtube#videoListResponse | 6vpwdu3zRh9nSao3RZngbX4XIGg | DataFrame [50 x 4]
... showing only top 5 of 50 rows | 50 | 50 | |||||||||||||||||||||||||||||||||||||||||||||||||
youtube#videoListResponse | mR3ZF95yRzBr_ldz27yQeXTsXjA | DataFrame [17 x 4]
... showing only top 5 of 17 rows | 17 | 17 |
val stats = statPages.items.concat().select { id and statistics.allCols() }.parse()
stats
id | viewCount | likeCount | favoriteCount | commentCount |
---|---|---|---|---|
y0sF5xhGreA | 16895225 | 61990 | 0 | 2363 |
3bhkYoMWTFE | 400310109 | 9621239 | 0 | 59132 |
NsMKvVdEPkw | 264068099 | 3255953 | 0 | 11992 |
wdjpworLSk8 | 118558748 | 1900361 | 0 | 6928 |
NlxYY7w1UGU | 70899688 | 1807692 | 0 | 10668 |
0KJS_2d2jOk | 54411772 | 873947 | 0 | 3826 |
DrpvkCRE2P4 | 53934142 | 1094929 | 0 | 5284 |
a7K-kWT_C2A | 84704502 | 3144403 | 0 | 18183 |
28O4PxyCG9E | 91891031 | 3417894 | 0 | 149746 |
MlDtL2hIj-Q | 1254735 | 5458 | 0 | 239 |
cytJLvf-eVs | 37046538 | 249531 | 0 | 5119 |
afm0c53xO2o | 78232163 | 1813169 | 0 | 3665 |
ASFCURj-2hQ | 44882515 | null | 0 | 1342 |
Po098TRdOn4 | 50213386 | 864356 | 0 | 3523 |
3AfETaI8Ias | 22716130 | 1421664 | 0 | 11536 |
0AwB4ivE-Uw | 7849981 | 88369 | 0 | 25 |
tpiyEe_CqB4 | 14955489 | 104867 | 0 | 5732 |
adbGYRuZ5OQ | 20807209 | 240005 | 0 | 731 |
2M1AFRWPpy8 | 147683299 | 1400823 | 0 | 826 |
DiEJQ3ZgQvI | 142693751 | 3096538 | 0 | 5718 |
val joined = clean.join(stats)
joined
id | title | publishedAt | channel | video | viewCount | likeCount | favoriteCount | commentCount | |
---|---|---|---|---|---|---|---|---|---|
channelId | channelTitle | ||||||||
y0sF5xhGreA | 20 Minutes of Adorable Kittens | B... | 2023-05-28T13:00:44Z | UCPIvT-zcQl2H0vabdXJGcpg | The Pet Collective | <iframe src="https://www.youtube.com/... | 16895225 | 61990 | 0 | 2363 |
3bhkYoMWTFE | Cats Doing Cat Things (3) | 2023-07-26T13:33:50Z | UCkMrzpvOdM2Ndc21jgbj8NA | catvid-19 | <iframe src="https://www.youtube.com/... | 400310109 | 9621239 | 0 | 59132 |
NsMKvVdEPkw | Kitten meowing to attract cats | 2023-05-06T14:18:05Z | UCDbVjtCeUnZliM4wTkhq2Lg | Cute Baby Cats 267 | <iframe src="https://www.youtube.com/... | 264068099 | 3255953 | 0 | 11992 |
wdjpworLSk8 | Cute kittens❤️【30】#shorts #cutecat520... | 2023-09-15T22:02:00Z | UCQQcnrcfQbWvCl2lBvF5hoQ | Cute Cat | <iframe src="https://www.youtube.com/... | 118558748 | 1900361 | 0 | 6928 |
NlxYY7w1UGU | Cat videos cute cats kittens | 2024-01-08T13:13:21Z | UCTmml_z2rBmxDUA9Ie4o_uA | Little Kitten 21 | <iframe src="https://www.youtube.com/... | 70899688 | 1807692 | 0 | 10668 |
0KJS_2d2jOk | 13❤Cute kitten #cat #lovecats #ca... | 2024-08-23T23:46:27Z | UCXGm1fhynaYAFwaOxBSTPNg | Cat Kitten | <iframe src="https://www.youtube.com/... | 54411772 | 873947 | 0 | 3826 |
DrpvkCRE2P4 | Cute baby kitten sound ❤️ #shorts | 2023-05-25T10:30:02Z | UCO5aEyYJeUXv8rxQEvbUMeA | Lovely Kittens | <iframe src="https://www.youtube.com/... | 53934142 | 1094929 | 0 | 5284 |
a7K-kWT_C2A | Funny Cute Cats | 2023-07-22T05:27:58Z | UCsVD3ZguqePDEKaPHUeaIuQ | ThomasTrucker | <iframe src="https://www.youtube.com/... | 84704502 | 3144403 | 0 | 18183 |
28O4PxyCG9E | My Kitten's Name Reveal! #cat #cu... | 2023-12-25T07:55:44Z | UCRSLeYO3BOhRAYz0vLfVSWw | SugarStar | <iframe src="https://www.youtube.com/... | 91891031 | 3417894 | 0 | 149746 |
MlDtL2hIj-Q | 30 Minutes of the Worlds CUTEST Kitte... | 2023-11-19T19:00:10Z | UCPIvT-zcQl2H0vabdXJGcpg | The Pet Collective | <iframe src="https://www.youtube.com/... | 1254735 | 5458 | 0 | 239 |
cytJLvf-eVs | Baby Cats - Cute and Funny Cat Videos... | 2020-02-05T15:49:45Z | UC8hC-augAnujJeprhjI0YkA | Aww Animals | <iframe src="https://www.youtube.com/... | 37046538 | 249531 | 0 | 5119 |
afm0c53xO2o | Kitten Arrival! #CatLovers #CuteCats ... | 2024-06-26T17:41:01Z | UCI7EM9d6P4wRWRjbFXcxUlQ | susan chan | <iframe src="https://www.youtube.com/... | 78232163 | 1813169 | 0 | 3665 |
ASFCURj-2hQ | Cat & cute baby laughing vi... | 2024-09-26T03:51:17Z | UCntAD-sZOPUXRIcw9syL-MQ | Toon4 | <iframe src="https://www.youtube.com/... | 44882515 | null | 0 | 1342 |
Po098TRdOn4 | Funny cat videos | cute cats | Try... | 2023-01-02T09:46:11Z | UC6OZkZ7VcRGNMV1uQwnt9Gg | SRH Funny cats | <iframe src="https://www.youtube.com/... | 50213386 | 864356 | 0 | 3523 |
3AfETaI8Ias | Kisa ❤️ #cat #cats | 2023-02-21T18:58:48Z | UCS56r87Y7q1SrAB-42brE-w | Sonyakisa8 TT | <iframe src="https://www.youtube.com/... | 22716130 | 1421664 | 0 | 11536 |
0AwB4ivE-Uw | Cute cats and monkey take my birthday... | 2024-10-18T01:33:00Z | UC0HRkOUeR4l1qwpRf9gLmdA | Lovie Jennaira | <iframe src="https://www.youtube.com/... | 7849981 | 88369 | 0 | 25 |
tpiyEe_CqB4 | Cute and Funny Cat Videos to Keep You... | 2020-04-10T16:00:28Z | UCzn2gx8zzhF0A4Utk8TEDNQ | Rufus | <iframe src="https://www.youtube.com/... | 14955489 | 104867 | 0 | 5732 |
adbGYRuZ5OQ | #cutecats #miaw #miawmiaw #miau #baby... | 2024-09-06T09:21:51Z | UCKCc6gU1ZMSVtsewQ4GaczQ | DIARY DIMURA | <iframe src="https://www.youtube.com/... | 20807209 | 240005 | 0 | 731 |
2M1AFRWPpy8 | Cute cats and kittens steals my kinde... | 2024-06-27T12:23:24Z | UC0HRkOUeR4l1qwpRf9gLmdA | Lovie Jennaira | <iframe src="https://www.youtube.com/... | 147683299 | 1400823 | 0 | 826 |
DiEJQ3ZgQvI | Cute Kitten of Cat is doing Makeup fo... | 2024-10-13T08:18:58Z | UCI3-YbYcx-rfnQjwU9P9fwg | Lovento Films | <iframe src="https://www.youtube.com/... | 142693751 | 3096538 | 0 | 5718 |
val view by column<Int>()
val channels = joined.groupBy { channel }.sortByCount().aggregate {
viewCount.sum() into view
val last = maxBy { publishedAt }
last.title into "last title"
last.publishedAt into "time"
last.viewCount into "viewCount"
}.sortByDesc(view).flatten()
channels
channelId | channelTitle | view | last title | time | viewCount |
---|---|---|---|---|---|
UCS56r87Y7q1SrAB-42brE-w | Sonyakisa8 TT | 1162091944 | Bath time #cat #cats | 2023-08-17T12:53:24Z | 129838203 |
UCvlE5gTbOvjiolFlEm-c_Ow | Vlad and Niki | 438956578 | Vlad and Niki play with Kittens | 2020-05-16T07:17:55Z | 438956578 |
UCzybj8GhOrPvWv_ZctJAlAw | Prince Tom | 429644502 | I lost my kitten on the street #cat... | 2024-07-17T02:00:12Z | 429644502 |
UCkMrzpvOdM2Ndc21jgbj8NA | catvid-19 | 400310109 | Cats Doing Cat Things (3) | 2023-07-26T13:33:50Z | 400310109 |
UCuSkK03h80AhO4IkvaSWdow | exlittlebeans | 278563438 | Boom,Scared me! #exlittlebeans #funny... | 2023-08-12T14:26:13Z | 225152620 |
UCI3-YbYcx-rfnQjwU9P9fwg | Lovento Films | 272574025 | Spooky Clown is after cute Cat and Ki... | 2024-11-18T08:48:39Z | 36137398 |
UCDbVjtCeUnZliM4wTkhq2Lg | Cute Baby Cats 267 | 264068099 | Kitten meowing to attract cats | 2023-05-06T14:18:05Z | 264068099 |
UCrj6b6NZy_EY_hmIfI9e63Q | Catfuntv | 246194482 | Revenge of father , yellow cat ... | 2024-03-29T11:00:29Z | 124326933 |
UC0HRkOUeR4l1qwpRf9gLmdA | Lovie Jennaira | 208786703 | cute cats and black dog take my kinde... | 2025-03-05T01:05:49Z | 58174 |
UCO5aEyYJeUXv8rxQEvbUMeA | Lovely Kittens | 173651757 | Kitten meow meow #shorts | 2023-08-09T01:30:01Z | 114348847 |
UCxqFuYecNu2SZMDrnvhCXtw | Baby Boom-Boom | 169567149 | Cat Meowing|Cat Sound| Cute C... | 2022-12-30T10:00:50Z | 169567149 |
UCTmml_z2rBmxDUA9Ie4o_uA | Little Kitten 21 | 142105352 | Cat Videos Cute Cats Kittens | 2025-01-23T10:45:34Z | 167841 |
UCNtnAu54xWLWGNZmmFy2Apw | MIRANO | 135602699 | funny and cute cats #shortvideo #shorts | 2023-07-02T10:00:28Z | 135602699 |
UCQQcnrcfQbWvCl2lBvF5hoQ | Cute Cat | 118558748 | Cute kittens❤️【30】#shorts #cutecat520... | 2023-09-15T22:02:00Z | 118558748 |
UCRSLeYO3BOhRAYz0vLfVSWw | SugarStar | 102057456 | Cats but they're in a mystery bag... | 2024-04-03T06:59:46Z | 10166425 |
UCi_HGn2j_zhU_NXqRbVbhww | Meow Motion | 87282728 | What u do if phone drops in toilet?#c... | 2024-03-21T07:47:53Z | 87282728 |
UCCmFz2da-mOk86Rn1-cqkGw | Bunch Of Viral | 86042217 | bride cat | #beautifulcat #yt | 2024-07-28T01:03:30Z | 86042217 |
UCsVD3ZguqePDEKaPHUeaIuQ | ThomasTrucker | 84704502 | Funny Cute Cats | 2023-07-22T05:27:58Z | 84704502 |
UCI7EM9d6P4wRWRjbFXcxUlQ | susan chan | 78232163 | Kitten Arrival! #CatLovers #CuteCats ... | 2024-06-26T17:41:01Z | 78232163 |
UCssBz_9Te2OFHBdgfgt89Lw | Cute cat's | 76273920 | #cat #cute #cats #cats101 #shorts #sh... | 2025-03-03T00:00:29Z | 194134 |
%use kandy
channels.sortBy { viewCount.desc() }.plot {
bars {
x(channelTitle.map { it.take(10) })
y(viewCount)
}
}
val growth = joined
.select { publishedAt and viewCount }
.sortBy { publishedAt }
.convert { all() }.toLong()
.cumSum { viewCount }
growth.plot {
area {
x(publishedAt)
y(viewCount)
}
}