将数字转换为逗号

Man*_*ias 7 r decimal comma

如果我有一个数据框:

a   b  
2.4 4.6
3.6 66.7
5.8 44.6
Run Code Online (Sandbox Code Playgroud)

a和b都是数字.

我想转换"." 与","

df$a <- as.numeric(gsub(".", ",", df$a))
Run Code Online (Sandbox Code Playgroud)

但我总是得到

Warning message:NAs introduced by coercion
Run Code Online (Sandbox Code Playgroud)

并且所有值都转换为NA.为什么?

Rom*_*kyi 15

你最初的想法几乎是正确的,只是正则表达式是错误的,因为.匹配任何符号.你需要类似的东西(这会将数字向量转换为字符向量)

df$a <- gsub("\\.", ",", df$a)
Run Code Online (Sandbox Code Playgroud)

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

options(OutDec= ",")

另一种选择是使用format功能.

format(df, decimal.mark=",")
Run Code Online (Sandbox Code Playgroud)

我假设您关心数字的打印方式(输出),因为内部数字存储为双精度浮点数(更新归功于@digemall的评论).另外,除非为某些函数read.table特别指定小数分隔符,,否则不可能这样做,因为默认情况下,用于分隔函数参数.

并且NA正是出于这个原因而引入(除了不正确的正则表达式).

df$a <- as.numeric(gsub("\\.", ",", df$a))
Run Code Online (Sandbox Code Playgroud)

默认情况下,解析器不知道它,是否用作小数分隔符.

  • @romantsegelskyi:_-内部始终存储.对于小数分隔符-_这是不正确的.使用IEEE 754双精度浮点标准在64位上存储数字,并且没有"点"符号(简单的1位表示符号,11位表示指数,52表示分数)请参阅[LINK](http: //en.wikipedia.org/wiki/Double-precision_floating-point_format) (2认同)