r - bit64 NA 不会在 data.frame 构造函数中复制

标签 r dataframe bit64

在构建数据框时,如果长度不同,列将被复制。

> data.frame(x = c(1,2), y = NA_integer_)
  x  y
1 1 NA
2 2 NA
但是,当我尝试使用 bit64::NA_integer64_ 执行此操作时,我收到一个错误。有谁知道会发生什么? rep()如果在 bit64::NA_integer64_ 上单独调用,则有效.
> data.frame(x = c(1,2), y = bit64::NA_integer64_)
Error in data.frame(x = c(1, 2), y = bit64::NA_integer64_) : 
  arguments imply differing number of rows: 2, 1
> rep(bit64::NA_integer64_, 2)
integer64
[1] <NA> <NA>

最佳答案

data.frame只会回收:

  • 除了 names 之外没有其他属性的向量
  • factor
  • AsIs character
  • Date
  • POSIXct
  • tibble没有这个问题。
    tibble::tibble(x = c(1,2), y = bit64::NA_integer64_)
    #> # A tibble: 2 x 2
    #>       x       y
    #>   <dbl> <int64>
    #> 1     1      NA
    #> 2     2      NA
    
    这是来自 data.frame 的相关片段
    for (i in seq_len(n)[nrows < nr]) {
        xi <- vlist[[i]]
        if (nrows[i] > 0L && (nr%%nrows[i] == 0L)) {
            xi <- unclass(xi)
            fixed <- TRUE
            for (j in seq_along(xi)) {
                xi1 <- xi[[j]]
                if (is.vector(xi1) || is.factor(xi1)) 
                  xi[[j]] <- rep(xi1, length.out = nr)
                else if (is.character(xi1) && inherits(xi1, "AsIs")) 
                  xi[[j]] <- structure(rep(xi1, length.out = nr), 
                    class = class(xi1))
                else if (inherits(xi1, "Date") || inherits(xi1, "POSIXct")) 
                  xi[[j]] <- rep(xi1, length.out = nr)
                else {
                  fixed <- FALSE
                  break
                }
            }
            if (fixed) {
                vlist[[i]] <- xi
                next
            }
        }
        stop(gettextf("arguments imply differing number of rows: %s", 
            paste(unique(nrows), collapse = ", ")), domain = NA)
    }
    

    关于r - bit64 NA 不会在 data.frame 构造函数中复制,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63286549/

    相关文章:

    python - Pandas 按列中列表的长度排序

    r - NA 之前的第一个和最后一个值

    Rcpp 和 int64 NA 值

    r - 图例位置,ggplot,相对于绘图区域

    使用查找表 dplyr 替换字符串

    为 R 中数据框的每一行返回缺少 (NA) 数据的列名列表

    替换 DataFrame 中的值

    r - Shiny:从列表列表生成selectInput直接进入最深层

    r - big64 - NA 向量上的 sum() 产生奇怪的结果

    r - `%in%` 对于整数64 的操作不正确