5

ファイルに空白行が多い場合、RのreadLinesで空白行を削除する方法は?

blank.lines.skip=Tin を使用しread.tableて削除できることはわかっていますが、 in はreadLinesどうですか?

\nまた、 readLinesで最後を削除するにはどうすればよいですか?

4

2 に答える 2

5

選択演算子を使用して、readLinesによって返される文字ベクトルから空白以外の行を見つけるのはどうですか?

# character vector mimicking readLine output, lines 2, 4, and 5 are blank
lines <- c("aaa", "", "ccc", "", "")
# [1] "aaa" ""    "ccc" ""    ""

# select lines which are blank
lines[which(lines=="")]
# [1] "" "" ""

# conversely, lines which are not
lines[which(lines!="")]
# [1] "aaa" "ccc"

上記の偽のreadLineデータを使用しましたが、実際には\n、空白行または最後の行に対してreadLinesが返されることはありません。

于 2012-08-08T13:53:25.307 に答える
3

再現可能な例:

  Z <- readLines(textConnection("line1 , stuff, other stuff\nline2 ,junk\nline3, a blank two lines follow\n\n\nline6\n"))
>     Z
[1] "line1 , stuff, other stuff"      "line2 ,junk"                     "line3, a blink two lines follow"
[4] ""                                ""                                "line6"                          
[7] ""                               
>     Z1 <- Z[sapply(Z, nchar) > 0] # the zero length lines get removed.
> Z1
[1] "line1 , stuff, other stuff"      "line2 ,junk"                     "line3, a blank two lines follow"
[4] "line6"          

@Andrieは、次のようなことを提案していました:

> Z <- scan(textConnection("line1 , stuff, other stuff\nline2 ,junk\nline3, a blink two lines follow\n\n\nline6\n"), 
            what="", sep="\n",blank.lines.skip=TRUE)
Read 4 items
>     Z
[1] "line1 , stuff, other stuff"      "line2 ,junk"                     "line3, a blink two lines follow"
[4] "line6" 
于 2012-08-08T15:06:34.063 に答える