[英]how to convert a string into numeric values in R
我有一个类似“ [0 0.1 0.2 0.4]”的字符串,我想要的是去除括号并以数字形式检索值。 我可以去除括号,但是当涉及到转换为数字时,则出现NA错误:
cleanList <- function(aString){
temp <- gsub("\\[|\\]", "", aString)
as.numeric(temp)
}
有没有一种方法可以将字符串中的每个字符转换为数字?
编辑:这是使用纵梁的另一种方法:
cleanList <- function(aString){
as.numeric(str_extract_all(aString,"\\(?[0-9,.]+\\)?")[[1]])
}
cleanList("[0 0.1 0.2 0.4]")
[1] 0.0 0.1 0.2 0.4
您需要将temp
拆分为一个向量,然后在其上调用as.numeric
。 假设temp
中的数字用空格隔开,
temp2 <- unlist(strsplit(temp, " "))
as.numeric(temp2)
# 0.0 0.1 0.2 0.4
另外, do.call(as.numeric, strsplit(temp, " "))
也可以工作。
使用strsplit
:
as.numeric( strsplit( temp, " " )[[1]] )
有关详细信息,请参见?strsplit
上的文档。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.