如何在 R 中使用 gsub 从字符串中删除非数字字符?

How can I remove non-numeric characters from strings using gsub in R?

我使用 R 中的 gsub 函数删除数字中不需要的字符。所以我应该从字符串中删除每个不是数字的字符,.-。我的问题是正则表达式没有删除一些非数字字符,例如 d+<.

下面是我的正则表达式、gsub 执行及其输出。如何更改正则表达式以获得所需的输出?

当前输出:

gsub(pattern = '[^(-?(\d*\.)?\d+)]', replacement = '', x = c('1.2<', '>4.5', '3+.2', '-1d0', '2aadddab2','1.3h'))
[1] "1.2<"  ">4.5"  "3+.2"  "-1d0"  "2ddd2" "1.3"

期望输出:

[1] "1.2"  "4.5"  "3.2"  "-10"  "22" "1.3"

谢谢。

简单使用

gsub("[^0-9.-]", "", x)

如果有多个 -.,您可以使用第二个 regEx 来处理。 如果您遇到困难,请提出一个新问题。


(如果需要,请确保将 . 更改为 ,