首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >R data.table文本解析

R data.table文本解析
EN

Stack Overflow用户
提问于 2014-01-30 19:28:47
回答 1查看 320关注 0票数 5

我有一个data.table,列中包含“Exp928.6.3 (DMSO)”这样的文本。我想将其解析为像"Exp 928“和"6.3”这样的列。似乎强大的data.table应该能够快速完成这一任务,但我不知道如何使它屈从于我的意志。有什么想法吗?

谢谢,詹姆斯

代码语言:javascript
复制
> dput(head(dat))
structure(list(Experiment = c("Exp 927.1.1 (DMSO)", "Exp 927.1.2 (DMSO)", 
"Exp 927.1.3 (DMSO)", "Exp 927.1.4 (DMSO)", "Exp 927.1.5 (DMSO)", 
"Exp 927.1.6 (DMSO)"), Conc.1..LP9. = c("Failed", "Failed", "Failed", 
"Failed", "Failed", "0.97"), Conc.2..LP11. = c("Failed", "Failed", 
"Failed", "Failed", "Failed", "0.87"), Conc.3..LP13. = c("Failed", 
"Failed", "Failed", "Failed", "Failed", "0.81"), Conc.4..LP15. = c("Failed", 
"Failed", "Failed", "Failed", "Failed", "0.76"), Conc.5..LP17. = c("Failed", 
"Failed", "Failed", "Failed", "Failed", "0.58"), Conc.1.uM..µM. = c("Failed", 
"Failed", "Failed", "Failed", "Failed", "0.001"), Conc.2.uM..µM. = c("Failed", 
"Failed", "Failed", "Failed", "Failed", "0.01"), Conc.3.uM..µM. = c("Failed", 
"Failed", "Failed", "Failed", "Failed", "0.1"), Conc.4.uM..µM. = c("Failed", 
"Failed", "Failed", "Failed", "Failed", "1"), Conc.5.uM..µM. = c("Failed", 
"Failed", "Failed", "Failed", "Failed", "10"), exptNo = list(
"927", "1", "1", "927", "1", "1"), sample = c("927", "1", 
"2", "927", "1", "2"), replicate = c("927", "1", "3", "927", 
"1", "3")), .Names = c("Experiment", "Conc.1..LP9.", "Conc.2..LP11.", 
"Conc.3..LP13.", "Conc.4..LP15.", "Conc.5..LP17.", "Conc.1.uM..µM.", 
"Conc.2.uM..µM.", "Conc.3.uM..µM.", "Conc.4.uM..µM.", "Conc.5.uM..µM.", 
"exptNo", "sample", "replicate"), sorted = "Experiment", class = c("data.table", 
"data.frame"), row.names = c(NA, -6L), .internal.selfref = <pointer: 0x0000000000130788>)
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-01-30 19:46:25

我认为有更简单的解决办法,

代码语言:javascript
复制
dat[,do.call(rbind,
        strsplit(gsub( "(.*?)[.](.*) .*","\\1|\\2",Experiment),'[|]'))]

   [,1]      [,2] 
[1,] "Exp 927" "1.1"
[2,] "Exp 927" "1.2"
[3,] "Exp 927" "1.3"
[4,] "Exp 927" "1.4"
[5,] "Exp 927" "1.5"
[6,] "Exp 927" "1.6"
票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/21465752

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档