如果我有一个数据框:
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)
默认情况下,解析器不知道它,是否用作小数分隔符.