如何在 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 来处理。
如果您遇到困难,请提出一个新问题。
(如果需要,请确保将 .
更改为 ,
)
我使用 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 来处理。
如果您遇到困难,请提出一个新问题。
(如果需要,请确保将 .
更改为 ,
)