- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
有人刚刚发布了一些控制台输出作为示例。 (这种情况经常发生,我有转换向量和数据帧打印输出的策略。)我想知道是否有人有一种优雅的方法将其解析为真正的 R 列表?
test <- "[[1]]
[1] 1.0000 1.9643 4.5957
[[2]]
[1] 1.0000 2.2753 3.8589
[[3]]
[1] 1.0000 2.9781 4.5651
[[4]]
[1] 1.0000 2.9320 3.5519
[[5]]
[1] 1.0000 3.5772 2.8560
[[6]]
[1] 1.0000 4.0150 3.1937
[[7]]
[1] 1.0000 3.3814 3.4291"
L <-
structure(list(a = structure(list(d = 1:2, j = 5:6, o = structure(list(
w = 2, 4), .Names = c("w", ""))), .Names = c("d", "j", "o"
)), b = "c", c = 3:4), .Names = c("a", "b", "c"))
> L
$a
$a$d
[1] 1 2
$a$j
[1] 5 6
$a$o
$a$o$w
[1] 2
$a$o[[2]]
[1] 4
$b
[1] "c"
$c
[1] 3 4
str
处理列表,但它本质上是在做逆变换。我认为这需要沿着这些路线进行一些结构化,其中将递归调用类似这种逻辑的东西,因为列表可以命名(其中最后一个索引前会有“$”)或未命名(在这种情况下“[[.]]”中会有一个数字。
parseTxt <- function(Lobj) {
#setup logic
# Untested code... basically a structure to be filled in
rdLn <- function(Ln) {
for( ln in length(inp) ) {
m <- gregexpr("\\[\\[|\\$", "$a$o[[2]]")
separators <- regmatches("$a$o[[2]]", m)
curr.nm=NA
if ( tail( separators, 1 ) == "$" ){
nm <- sub("^.+\\$","",ln)
if( !nm %in% curr.nm){ curr.nm <-c(nm, curr.nm) }
} else { if (tail( separators, 1 ) == '[[' ){
# here need to handle "[[n]]" case
} else { and here handle the "[n]" case
}
}
}
最佳答案
这是我对解决方案的看法。它适用于您的测试用例以及我测试过的其他几个测试用例。
deprint <- function(ll) {
## Pattern to match strings beginning with _at least_ one $x or [[x]]
branchPat <- "^(\\$[^$[]*|\\[\\[[[:digit:]]*\\]\\])"
## Pattern to match strings with _just_ one $x or one [[x]]
trunkPat <- "^(\\$[^$[]*|\\[\\[[[:digit:]]*\\]\\])\\s*$"
##
isBranch <- function(X) {
grepl(branchPat, X[1])
}
## Parse character vectors of lines like "[1] 1 3 4" or
## "[1] TRUE FALSE" or c("[1] a b c d", "[5] e f")
readTip <- function(X) {
X <- paste(sub("^\\s*\\[.*\\]", "", X), collapse=" ")
tokens <- scan(textConnection(X), what=character(), quiet=TRUE)
read.table(text = tokens, stringsAsFactors=FALSE)[[1]]
}
## (0) Split into vector of lines (if needed) and
## strip out empty lines
ll <- readLines(textConnection(ll))
ll <- ll[ll!=""]
## (1) Split into branches ...
trunks <- grep(trunkPat, ll)
grp <- cumsum(seq_along(ll) %in% trunks)
XX <- split(ll, grp)
## ... preserving element names, where present
nms <- sapply(XX, function(X) gsub("\\[.*|\\$", "", X[[1]]))
XX <- lapply(XX, function(X) X[-1])
names(XX) <- nms
## (2) Strip away top-level list identifiers.
## pat2 <- "^\\$[^$\\[]*"
XX <- lapply(XX, function(X) sub(branchPat, "", X))
## (3) Step through list elements:
## - Branches will need further recursive processing.
## - Tips are ready to parse into base type vectors.
lapply(XX, function(X) {
if(isBranch(X)) deprint(X) else readTip(X)
})
}
L
,您更复杂的示例列表,这是它给出的内容:
## Because deprint() interprets numbers without a decimal part as integers,
## I've modified L slightly, changing "list(w=2,4)" to "list(w=2L,4L)"
## to allow a meaningful test using identical().
L <-
structure(list(a = structure(list(d = 1:2, j = 5:6, o = structure(list(
w = 2L, 4L), .Names = c("w", ""))), .Names = c("d", "j", "o"
)), b = "c", c = 3:4), .Names = c("a", "b", "c"))
## Capture the print representation of L, and then feed it to deprint()
test2 <- capture.output(L)
LL <- deprint(test2)
identical(L, LL)
## [1] TRUE
LL
## $a
## $a$d
## [1] 1 2
##
## $a$j
## [1] 5 6
##
## $a$o
## $a$o$w
## [1] 2
##
## $a$o[[2]]
## [1] 4
##
## $b
## [1] "c"
##
## $c
## [1] 3 4
test
的打印表示,您更常规的列表:
deprint(test)
## [[1]]
## [1] 1.0000 1.9643 4.5957
##
## [[2]]
## [1] 1.0000 2.2753 3.8589
##
## [[3]]
## [1] 1.0000 2.9781 4.5651
##
## [[4]]
## [1] 1.0000 2.9320 3.5519
##
## [[5]]
## [1] 1.0000 3.5772 2.8560
##
## [[6]]
## [1] 1.0000 4.0150 3.1937
##
## [[7]]
## [1] 1.0000 3.3814 3.4291
head(as.data.frame(deprint(capture.output(as.list(mtcars)))))
# mpg cyl disp hp drat wt qsec vs am gear carb
# 1 21.0 6 160 110 3.90 2.620 16.46 0 1 4 4
# 2 21.0 6 160 110 3.90 2.875 17.02 0 1 4 4
# 3 22.8 4 108 93 3.85 2.320 18.61 1 1 4 1
# 4 21.4 6 258 110 3.08 3.215 19.44 1 0 3 1
# 5 18.7 8 360 175 3.15 3.440 17.02 0 0 3 2
# 6 18.1 6 225 105 2.76 3.460 20.22 1 0 3 1
关于r - 将列表的控制台输出转换为真正的 R 列表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27217129/
缓冲区溢出问题是众所周知的。因此,我们有幸使用标准库函数,例如 wcscat_s()。 Microsoft 的好心人已经创建了类似的安全字符串函数,例如 StringCbCat()。 但是我遇到了一个
HTTP缓存相关的问题好像是前端面试中比较常见的问题了,上来就会问什么cache-control字段有哪些,有啥区别啥的。嗯……说实话,我觉得至少在本篇来说,HTTP缓存还算不上复杂,只是字段稍
代理,其实全称应该叫做代理服务器,它是客户端与服务器之间得中间层,本质上来说代理就是一个服务器,在HTTP的链路中插入的一个中间环节,就是代理服务器啦。所谓的代理服务就是指:服务本身不生产内容,
我们在前两篇的内容中分别学习了缓存和代理,大致了解了缓存有哪些头字段,代理是如何服务于服务器和客户端的,那么把两者结合起来,代理缓存,也就是说代理服务器也可以缓存,当客户端请求数据的时候,未必一
在前面的章节,我们把HTTP/1.1的大部分核心内容都过了一遍,并且给出了基于Node环境的一部分示例代码,想必大家对HTTP/1.1已经不再陌生,那么HTTP/1.1的学习基本上就结束了。这两
我们前一篇学习了HTTP/2,相比于HTTP/1,HTTP/2在性能上有了大幅的改进,但是HTTP/2因为底层还是基于TCP协议的,虽然HTTP/2在应用层引入了流的概念,利用多路复用解决了队头
前面我们花了很大的篇幅来讲HTTP在性能上的改进,从1.0到1.1,再到2.0、3.0,HTTP通过替换底层协议,解决了一直阻塞性能提升的队头阻塞问题,在性能上达到了极致。 那么,接下
上一篇噢,我们搞明白了什么是安全的通信,这个很重要,特别重要,敲黑板!! 然后,我们还学了HTTPS到底是什么,以及HTTPS真正的核心SSL/TLS是什么。最后我们还聊了聊TLS的实
经过前两章的学习,我们知道了通信安全的定义以及TLS对其的实现~有了这些知识作为基础,我们现在可以正式的开始研究HTTPS和TLS协议了。嗯……现在才真正开始。 我记得之前大概聊过,当
这一篇文章,我们核心要聊的事情就是HTTP的对头阻塞问题,因为HTTP的核心改进其实就是在解决HTTP的队头阻塞。所以,我们会讲的理论多一些,而实践其实很少,要学习的头字段也只有一个,我会在最开始
我们在之前的文章中介绍HTTP特性的时候聊过,HTTP是无状态的,每次聊起HTTP特性的时候,我都会回忆一下从前辉煌的日子,也就是互联网变革的初期,那时候其实HTTP不需要有状态,就是个浏览页面
前面几篇文章,我从纵向的空间到横向的时间,再到一个具体的小栗子,可以说是全方位,无死角的覆盖了HTTP的大部分基本框架,但是我聊的都太宽泛了,很多内容都是一笔带过,再加上一句后面再说就草草结束了。
我的问题确实很简单,是否应该对适配器(设计模式)类进行单元测试,以及如何进行测试? 例子: 我想用PHP创建一个ClientSocket类,它是fsockopen,fread,fwrite的适配器。
目前,我在 PHP 脚本中使用此查询: SELECT * FROM `ebooks` WHERE `id`!=$ebook[id] ORDER BY RAND() LIMIT 125; 数据库最多大约
我们都知道可以使用 GetCustomAttributes 方法查询程序集的属性。我想用它来识别我的应用程序的扩展模块。但是,为了避免加载每个程序集,我更喜欢防御性方法: 使用 Assembly.Re
我正在移植一个非常大的代码库,我在处理旧代码时遇到了更多困难。 例如,这会导致编译器错误: inline CP_M_ReferenceCounted * FrAssignRef(CP_M_Refere
[关于此主题还有其他类似的问题,但是它们都没有回答我在这里提出的问题,即AFAICT。 (即,我已经阅读了所有答案,解释了为什么特定构造无法与发问者尝试进行的操作,在某些情况下,它们提供了获得所需结果
嗨 我想为需要全屏运行的网络艺术应用程序构建一个控制面板,因此所有控制颜色和速度值等内容的面板都必须位于不同的窗口中。 我的想法是建立一个数据库来存储所有这些值,当我在控制面板窗口中进行更改时,应用程
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 9 年前。 Improve this qu
假设我想实现一个分布式数据库(每个节点都是其他节点的副本);我听说 cdb 能够轻松地在两个节点之间进行同步,并且至少支持某种形式的冲突解决。 不幸的是我不知道 couchdb 因此我不得不问:节点“
我是一名优秀的程序员,十分优秀!