这应该是一件容易做的事情。我在这里读到的类似的例子有点复杂,这些技术对我来说并不是真的有效。
我有一个名为id_string的变量
> typeof(id_string)
[1] "character"和
> id_string
[1] "1,2,5,6,10"我想做的是将这些值拆分出来,并将它们存储在一个新的变量中。使得,例如:
x[1] = 1
x[4] = 6
x[5] = 10我试着去做
x <- strsplit(id_string,",") 用逗号分隔,但我只得到x = "1 2 5 6 10"
我在这里阅读了类似的this post,我想像这样的东西
x <- read.csv(textConnection(id_string))将会奏效,但无济于事。
也许我想得太多了。如果你有什么想法,请告诉我。谢谢。
发布于 2010-12-18 04:59:07
我不确定你做错了什么,因为它的效果和广告宣传的一样。
> x <- unlist(strsplit("1,2,5,6,10", ","))
> x
[1] "1" "2" "5" "6" "10"
> x[1]
[1] "1"请记住,strsplit返回一个list。
发布于 2010-12-20 17:27:41
坚持使用上面列出的strsplit可能是最好的。
我认为read.csv没有做你所期望的事情,因为它正在寻找一个头文件。您可以尝试:
s <- "1,2,5,6,10"
read.csv(textConnection(s), header=FALSE)显式地告诉它不要查找标头。不过,您仍然需要从生成的data.frame中提取数字。您最好使用较低级别的函数scan,它将直接为您提供数字的向量:
scan(textConnection(s), sep=",", quiet=TRUE)https://stackoverflow.com/questions/4474671
复制相似问题