首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何从R中的大型固定宽度文件中读取特定列

如何从R中的大型固定宽度文件中读取特定列
EN

Stack Overflow用户
提问于 2014-07-04 10:27:30
回答 1查看 881关注 0票数 3

在R中是否有任何方便的方法从固定宽度的数据文件中读取特定列(或多列)?该文件如下所示:

代码语言:javascript
复制
10010100100002000000
00010010000001000000
10010000001002000000

比方说,我会对第15栏感兴趣。目前,我正在用read.fwf读取整个数据,并将1的向量作为宽度,其长度为列总数的长度:

代码语言:javascript
复制
data <- read.fwf("demo.asc", widths=rep(1,20))
data[,14]
[1] 2 1 2

这样做很好,但不会扩展到包含100,000多个列和行的数据集。有什么有效的方法来做到这一点吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-07-04 11:15:42

您可以使用连接并以块方式处理文件:

复制您的数据:

代码语言:javascript
复制
dat <-"10010100100002000000
00010010000001000000
10010000001002000000"

使用连接在块中处理:

代码语言:javascript
复制
# Define a connection
con = textConnection(dat)


# Do the block update
linesPerUpdate <- 2
result <- character()
repeat {
  line <- readLines(con, linesPerUpdate)
  result <- c(result, substr(line, start=14, stop=14))
  if (length(line) < linesPerUpdate) break
}

# Close the connection
close(con)

结果:

代码语言:javascript
复制
result
[1] "2" "1" "2"
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/24572252

复制
相关文章

相似问题

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