如何用R设置','作为小数分隔符

时间:2013-05-05 13:06:17

标签: r separator

即使我的Windows 7区域设置指定使用“,”作为小数点分隔符,R和RStudio也会给我一个“。”分隔器。有没有办法改变这个?请注意下面语言环境中的“LC_NUMERIC = C”设置:这似乎是由R或RStudio强制执行的。

由于我处于漫长的项目中,我不愿意立即改用R 3.0和最后一个RStudio版本。有谁知道这些版本中的小数分隔符问题是否有任何变化?

我使用prettyNum解决单个数字的问题,但我不知道如何在表上使用它。

sessionInfo()     R版本2.15.3(2013-03-01)     平台:x86_64-w64-mingw32 / x64(64位)

locale:
[1] LC_COLLATE=Spanish_Argentina.1252  LC_CTYPE=Spanish_Argentina.1252   
[3] LC_MONETARY=Spanish_Argentina.1252 LC_NUMERIC=C                      
[5] LC_TIME=Spanish_Argentina.1252    

attached base packages:
[1] grid      splines   stats     graphics  grDevices utils     datasets  methods  
[9] base     

other attached packages:
 [1] ascii_2.1          randomForest_4.6-7 pander_0.3.3       fpc_2.1-5         
 [5] flexmix_2.3-10     mclust_4.0         cluster_1.14.3     MASS_7.3-23       
 [9] Gmisc_0.5.0.0      testthat_0.7       boot_1.3-7         rms_3.6-3         
[13] miscTools_0.6-16   stringr_0.6.2      Hmisc_3.10-1       survival_2.37-2   
[17] lattice_0.20-13    xtable_1.7-1       pixmap_0.4-11      RColorBrewer_1.0-5
[21] ade4_1.5-1        

loaded via a namespace (and not attached):
[1] digest_0.6.3      evaluate_0.4.3    modeltools_0.2-19 stats4_2.15.3    
[5] tools_2.15.3  

3 个答案:

答案 0 :(得分:14)

read.tablewrite.table函数(及其大多数表兄弟)使用的小数点分隔符设置为“dec”参数。 read.csv2是一种特殊情况,dec的默认值为“,”,字段分隔符(“sep”)设置为“;”。

可以更改R打印,绘图和as.character功能的操作的输出。您可以使用以下命令将其更改为默认值:

 options(OutDec= ",")   # read ?options
 print( pi )
 #[1] 3,141593
 options(OutDec= ",")  # restore default value

这不会导致R以不同方式处理来自控制台的数字输入。这是硬编码为“。”作为小数点分隔符。

如果将一个文本函数应用于表对象,则可能会从“数字”模式强制转换为“字符”模式,因为R中的表对象继承自“矩阵”类。

答案 1 :(得分:2)

为什么要使用“,”作为小数分隔符,在这种情况下R将如何插入此R表达式

x <- c(2,3) # (two vectors or one). 

所以,我假设你只想覆盖默认的小数分隔符来打印输出,在这种情况下,我认为prettyNum是正确的工具。

require(plyr)
head(numcolwise(prettyNum)(iris, dec = ","))

##   Sepal.Length Sepal.Width Petal.Length Petal.Width
## 1          5,1         3,5          1,4         0,2
## 2          4,9           3          1,4         0,2
## 3          4,7         3,2          1,3         0,2
## 4          4,6         3,1          1,5         0,2
## 5            5         3,6          1,4         0,2
## 6          5,4         3,9          1,7         0,4

答案 2 :(得分:0)

基于你想在blog comment where you referenced this question中看到(Pandoc)降价使用它的事实,我还建议尝试一下pander package

> library(pander)
> panderOptions('decimal.mark', ',')
> panderOptions('table.split.table', Inf)
> pander(head(iris))

-------------------------------------------------------------------
 Sepal.Length   Sepal.Width   Petal.Length   Petal.Width   Species 
-------------- ------------- -------------- ------------- ---------
     5,1            3,5           1,4            0,2       setosa  

     4,9             3            1,4            0,2       setosa  

     4,7            3,2           1,3            0,2       setosa  

     4,6            3,1           1,5            0,2       setosa  

      5             3,6           1,4            0,2       setosa  

     5,4            3,9           1,7            0,4       setosa  
-------------------------------------------------------------------

或PHP Markdown Extra语法,以便更轻松地使用knitr

> pandoc.table(head(iris), style = 'rmarkdown')


|  Sepal.Length  |  Sepal.Width  |  Petal.Length  |  Petal.Width  |  Species  |
|:--------------:|:-------------:|:--------------:|:-------------:|:---------:|
|      5,1       |      3,5      |      1,4       |      0,2      |  setosa   |
|      4,9       |       3       |      1,4       |      0,2      |  setosa   |
|      4,7       |      3,2      |      1,3       |      0,2      |  setosa   |
|      4,6       |      3,1      |      1,5       |      0,2      |  setosa   |
|       5        |      3,6      |      1,4       |      0,2      |  setosa   |
|      5,4       |      3,9      |      1,7       |      0,4      |  setosa   |