正则表达式 – 测试字符串中的数字元素

我想测试一个字符串,看看哪些元素实际上可以是数字。我可以使用正则表达式测试整数成功,但我正在查看哪些元素具有所有数字和1个或更少的小数。以下是我试过的:
x <- c("0.33",".1","3","123","2.3.3","1.2r")
!grepl("[^0-9]",x)   #integer test

grepl("[^0-9[\\.{0,1}]]",x)  # I kNow it's wrong but don't kNow what to do

我正在寻找一个逻辑输出,所以我期望以下结果:

[1] TRUE TRUE TRUE TRUE FALSE FALSE
也许有一些原因您的数据更复杂,会打破这一点,但我的第一个想法是:
> !is.na(as.numeric(x))
[1]  TRUE  TRUE  TRUE  TRUE FALSE FALSE

如以下Josh O’Brien所述,这不会拾取像7L这样的东西,R解释器将解析为整数7.如果你需要将它们包括为“合理的数字”,那么一条路由将会被选出来正则表达式第一,

x <- c("1.2","1e4","1.2.3","5L")
> x
[1] "1.2"   "1e4"   "1.2.3" "5L"   
> grepl("^[[:digit:]]+L",x)
[1] FALSE FALSE FALSE  TRUE

…然后使用gsub和索引从这些元素剥离“L”。

相关文章

正则替换html代码中img标签的src值在开发富文本信息在移动端...
正则表达式
AWK是一种处理文本文件的语言,是一个强大的文件分析工具。它...
正则表达式是特殊的字符序列,利用事先定义好的特定字符以及...
Python界一名小学生,热心分享编程学习。
收集整理每周优质开发者内容,包括、、等方面。每周五定期发...