我有包含长整数的csv中的数据。我正在csvs和fst文件之间交换此数据。

例如,

library(bit64)
library(data.table)
library(fst)
library(magrittr)

# Prepare example csvs
DT64_orig <- data.table(x = (c(2345612345679, 1234567890, 8714567890)))
fwrite(DT64_orig, "DT64_orig.csv")

# Read and move to fst
DT64 <- fread("DT64_orig.csv")
write.fst(DT64, "DT64_fst.fst")

DT_fst2 <-
  read.fst("DT64_fst.fst") %>%
  setDT

# bit64 integers not preserved:
identical(DT_fst2, DT64)

有没有一种方法可以将fst文件用于包含data.table整数的bit64

最佳答案

看起来fst在保存或加载时可能会删除列属性(请在fst包上作为一个问题问)。您可以同时放回列类型。 bit64::integer64是引擎盖下的普通double,因此不会丢失任何位。只是类型信息告诉R如何打印列。

> DT_fst2
               x
1: 1.158886e-311
2: 6.099576e-315
3: 4.305569e-314
> setattr(DT_fst2$x, "class", "integer64")
> DT_fst2
               x
1: 2345612345679
2:    1234567890
3:    8714567890
> identical(DT_fst2, DT64)
[1] TRUE

关于r - 带fst的bit64整数,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/42379995/

10-12 22:39