我有一个像“[0 0.1 0.2 0.4]”的字符串,我想要的是删除括号并将值检索为数字。我能够删除括号,但是当转换为数字时,我的NA有一个错误:
cleanList <- function(aString){
temp <- gsub("\\[|\\]", "", aString)
as.numeric(temp)
}
有没有办法将字符串中的每个字符转换为数字?
编辑:这是另一种使用stringr的方法:
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
答案 0 :(得分:3)
您需要将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, " "))
也可以。
答案 1 :(得分:1)
使用strsplit
:
as.numeric( strsplit( temp, " " )[[1]] )
有关详细信息,请参阅?strsplit
上的文档。