【发布时间】:2021-12-19 23:59:29
【问题描述】:
我尝试为每种流派获取 50 首歌曲,并将它们放在具有流派名称的数据框中,但出现以下错误。
Error : object 'res' not found
我知道未定义的对象导致了问题,但我不知道如何处理它。 你能解释一下吗?
**Language:R, Environment: Exploratory Public**
genres <- RETRY('GET', url = 'https://api.spotify.com/v1/recommendations/available-genre-seeds', query = list(access_token = get_spotify_access_token(), limit=150), quiet = TRUE) %>% content()
m <- do.call(rbind,lapply(genres$genre, function(x) if(is.null(x)) NA else c(x)))
genres_df <- as.data.frame(m)
colnames(genres_df) <- c("genre")
get_genre_track <- function(genre){
track_check <- RETRY('GET', url = paste0("https://api.spotify.com/v1/search?query=genre%3A",genre), query = list(type="track",limit = 50, offset = 0, access_token = get_spotify_access_token()), quiet = TRUE) %>% content()
track_count <- 50
df <- map_df(1:length(res$tracks$items), function(this_row) {
tryCatch({
this_track <- res$tracks$items[[this_row]]
name <- this_track$name
genre <- genre
list(name = name, genre = genre)
}, error = function(e){
NULL
})
})
}
tracks_df <- lapply(genres_df$genre, get_genre_track) %>% bind_rows()
tracks_df
}
(需要的库安装和用户信息省略)
【问题讨论】:
-
res$tracks$items未在您的代码中定义。你期望这来自哪里?这应该从页面上刮下来吗?当您使用 Shift+Ctrl+C (Win) 检查页面并搜索“res”时,您看到什么了吗?你为什么选择这个对象名称 - 有没有你正在学习的教程? -
成功了!非常感谢您的回答。
标签: r api web-scraping spotify