我是R语言的初学者,在处理csv文件和矢量时需要帮助。
我有一个用以下格式分隔的csv文件:
id1 AA 44 AG 20 GG 36
id2 CC 30 CT 22 TT 48
id3 CT 60 CC 30 TT 10
...
并且我需要一个代码,该代码循环遍历每一行,并将id放入变量中,并将其余值放入向量中。与第一行相对应的向量示例:
x <- id1
y <- c(AA=40,AG=20,GG=36)
有帮助吗?
谢谢!
.csv
读取read.csv/read.table
文件在R中创建了一个对象),然后用asplit
按行拆分,但不包括第一列“ id”列,并创建一个setNames
的向量lst1 <- Map(setNames, asplit(df1[-1][c(FALSE, TRUE)], 1),
asplit(df1[-1][c(TRUE, FALSE)], 1))
names(lst1) <- df1[[1]]
lst1$id1
# AA AG GG
# 44 20 36
数据
df1 <- structure(list(id = c("id1", "id2", "id3"), v1 = c("AA", "CC",
"AA"), v2 = c(44L, 30L, 60L), v3 = c("AG", "CT", "AG"), v4 = c(20L,
22L, 30L), v5 = c("GG", "TT", "GG"), v6 = c(36L, 48L, 10L)),
class = "data.frame", row.names = c(NA,
-3L))