2

我正在尝试使用read_excel()“readxl”包中的函数将 excel 文件读入 R。excel 文件中单元格中的数字有 3 位小数,例如 0,684 1,338 74,296. 在 R 数据框中,相同的数字是0,684 1,34 74,3。为什么只剩下3位数?

我已经设置options(digits=5)(也尝试了不同的值)。

我也尝试过read_excel("file.xlsx", col_types = c("text", "text", "text"))(它给了我字符串:)74.296000000000006 1.3380000000000001 0.68400000000000005,然后用 转换为数字as.numeric(),但数字再次被截断:0,684 1,34 74,3

如果您知道原因,请告诉我:)

4

1 回答 1

3

小心不要混淆“有多少位数”与“R 向您显示多少位数”。如果没有看到您的代码,很难确定,但我怀疑您正在打印一个 tibble,如下所示:

library(readxl)
my_junk <- read_excel("~/Downloads/test.xlsx")
print(my_junk)
#> # A tibble: 3 x 1
#>    test
#>   <dbl>
#> 1 0.684
#> 2 1.000
#> 3 1.00

小标题的默认打印方法仅显示几个有效数字。而且它似乎没有响应options. 但是,如果我们将其转换为 data.frame,您会看到数字一直存在:

library(dplyr)
my_junk %>%
  data.frame %>%
  print( digits = 7)  
#>       test
#> 1 0.684000
#> 2 0.999950
#> 3 1.000001

所以你的数字很可能在那里,他们只是没有显示。

于 2018-08-09T23:18:52.443 回答