Rda 只是 RData 的简称。您可以像使用 RData 一样保存()、加载()、附加()等。
Rds 存储一个单个 R 对象。然而,除了这个简单的解释之外,与“标准”存储还有几个不同之处。可能这个 R-manual Link to readRDS() function 充分阐明了这些区别。
所以,回答你的问题:
区别不在于压缩,而在于序列化(请参阅此页面)
如手册页所示,您可能想使用它来恢复具有不同名称的某个对象,例如。
您可以选择性地读取 RDS() 和 save(),或者 load() 和 saveRDS()。
除了@KenM 的回答,另一个重要的区别是,在加载保存的对象时,您可以分配 Rds
文件的内容。 Rda
并非如此
> x <- 1:5
> save(x, file="x.Rda")
> saveRDS(x, file="x.Rds")
> rm(x)
## ASSIGN USING readRDS
> new_x1 <- readRDS("x.Rds")
> new_x1
[1] 1 2 3 4 5
## 'ASSIGN' USING load -- note the result
> new_x2 <- load("x.Rda")
loading in to <environment: R_GlobalEnv>
> new_x2
[1] "x"
# NOTE: `load()` simply returns the name of the objects loaded. Not the values.
> x
[1] 1 2 3 4 5