9

パッケージのfread()関数で問題が発生しました。data.tableまだ実験段階であることはわかっていますが、どこかで間違いを犯している可能性があります。

再現可能な例を次に示します。

library(data.table)
test <- data.frame(a=rnorm(300), b=rnorm(300))
write.csv(test,"a.csv")
fread("a.csv")

エラーが発生します:

Error in rbindlist(allargs) : 
  Item 2 has 2 columns, inconsistent with item 1 which has 3 columns

副次的な質問: なぜ私は疑問を残す必要がrow.names=TRUEあるのwrite.csvですか? これまでのところ、名前のない列が1つデータに追加されるため、問題はありませんでした。

どうも。

4

1 に答える 1

8

回避策として、行名を新しい列として読み取ることができます。header=FALSE

fread("a.csv",header=FALSE)
header' changed by user from 'auto' to FALSE
      V1                 V2                 V3
  1:                      a                  b
  2:   1  -1.55640470495795    -1.344760319214
  3:   2   2.89752713867643   2.48413035874463
  4:   3 -0.493990961968582  0.119727513514055
  5:   4  0.559770137546773   1.07420769675405
 ---                                          
297: 296  0.585750601363698  -1.59845801200953
298: 297 -0.867339301988422  0.776738489388772
299: 298 0.0942821874550108 -0.649440075398178
300: 299 -0.308039637386426 -0.840171787291445
301: 300  0.358526722813896    -1.362322309472

の助けから、freadすべての例が を使用しているように見えるrow.names=FALSEので、あなたが言及したように、これはうまくいきます:

write.csv(test,"b.csv",row.names=FALSE)
fread("b.csv")
于 2013-03-16T11:40:17.237 に答える