`vec_assign()` 函数报错:`value` 应该被循环使用以适应 `x`。这个错误想要告诉我什么?

5

我有一个函数用于基本的网络爬取。这个函数在成功登录后调用。(网站已被屏蔽 xxxxxx)

搜索函数:

search <-function(HorseList){
  url <- "http://tnetwork.xxxxxx.com/tnet/HorseSearch.aspx"
  s <- GET(url)
  xxxxxx <- tibble(
    horse_name = character(),
    race_date = character(),
    race_nbr = character(),
    trk = character(),
    peak = character(),
    dist_run = character()
  )
  for (row in 1:nrow(HorseList))
  {
    
    url <-paste(c('http://tnetwork.xxxxxx.com/tnet/HorseSearchAPI.aspx?HorseName=',toString(HorseList[[row, 1]])),collapse='')
    #print(url)
    h <- GET(url)
    temp<-content(h, "text")
    doc <- htmlParse(temp)
    horse_name <- HorseList[[row,1]]
    horse_ID <-xpathSApply(doc,"//*[@id=\"resultsDiv\"]/p[1]/a/@href")
    horse_ID <-substr(horse_ID,27,40)
    h_list <- list()
    c <- nchar(horse_ID)
    if (length(c)>0)
    {
      h_list[1] <- horse_ID
    }
    
    
    id_count <- length(h_list)
    
    for (k in 1:id_count)
    {
      url <-paste(c('http://tnetwork.xxxxxx.com/tnet/t_PastPerf.aspx?HorseID=',toString(h_list[k])),collapse='')
      t <- GET(url)
      temp <- content(t, "text")
      pastperf <- htmlParse(temp)
      row_count<-length(xpathSApply(pastperf,"//*[@id=\"pastPerfTable\"]/tr"))
      
      for(j in 2:row_count)
      {
        j<- toString(j)
        race_data <- xpathSApply(pastperf,paste("//*[@id=\"pastPerfTable\"]/tr[",j,"]/td[1][1]"),xmlValue)
        race_date <- substr(race_data,1,10)
        race_number <-trimws(substr(race_data,12,100))
        horse_name <- URLdecode(toString(horse_name))
        race_nbr = str_match(race_number,'(Race\\s\\d+)(.*)')[,2]
        trk = str_match(race_number,'(Race\\s\\d+)(.*)')[,3]
        peak <-xpathSApply(pastperf,paste("//*[@id=\"pastPerfTable\"]/tr[",j,"]/td[13]"),xmlValue)
        cum_distance <-xpathSApply(pastperf,paste("//*[@id=\"pastPerfTable\"]/tr[",j,"]/td[14]"),xmlValue)
        newrow <- paste(horse_name,',',race_date,',',race_nbr,',',trk, ',',peak,',',cum_distance)
        xxxxxx <- add_row(trakus, horse_name = horse_name, race_date = race_date, race_nbr = race_nbr, trk=trk, peak = peak, dist_run = cum_distance)
      }
    }
  }
  
  return(xxxxxx)
}

该函数在过去成功运行,但今天出现以下错误:

Error: Internal error in `vec_assign()`: `value` should have been recycled to fit `x`.

我运行了 rlang::last_error() 和 last_trace() 命令以获得一些额外的信息,但我仍然不确定发生了什么。

> rlang::last_error()
<error/rlang_error>
Internal error in `vec_assign()`: `value` should have been recycled to fit `x`.
Backtrace:
 1. base::source("~/TimeForm/Scripts/past_perf.R", echo = TRUE)
 6. global::search(horse_list) ~/TimeForm/Scripts/past_perf.R:627:2
 7. tibble::add_row(...) ~/TimeForm/Scripts/past_perf.R:85:8
 8. tibble:::rbind_at(.data, df, pos)
 9. vctrs::vec_rbind(old, new)
Run `rlang::last_trace()` to see the full context.

> rlang::last_trace()
<error/rlang_error>
Internal error in `vec_assign()`: `value` should have been recycled to fit `x`.
Backtrace:
     x
  1. +-base::source("~/TimeForm/Scripts/past_perf.R", echo = TRUE)
  2. +-base::source("~/TimeForm/Scripts/past_perf.R", echo = TRUE)
  3. | +-base::withVisible(eval(ei, envir))
  4. | \-base::eval(ei, envir)
  5. |   \-base::eval(ei, envir)
  6. \-global::search(horse_list) ~/TimeForm/Scripts/past_perf.R:627:2
  7.   \-tibble::add_row(...) ~/TimeForm/Scripts/past_perf.R:85:8
  8.     \-tibble:::rbind_at(.data, df, pos)
  9.       \-vctrs::vec_rbind(old, new)
 10.         \-(function () ...

看起来代码中的add_row()行可能是罪魁祸首,但我不确定错误在说什么或如何修复它。有人能分享一些见解吗?

1个回答

2

我发现问题出现在处理空字符字段、null值或使用NA时。通过map_if替换null值,问题得以解决。

    map_depth(.depth = 1, map_if, is_empty, ~paste0(""))

当然,您需要调整深度命令以在适当的层次结构水平上进行更正。
理想情况下,bind_rows()应更加稳健地处理包含NA或NULL值的向量。

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接