2013-10-22 34 views
6

basarken data frames için NA baskı yapmayın hiçbir na.printoption yoktur. NA'ların görüntülenmesini önlemek için herhangi bir geçici çözüm var mı?veri çerçevesini

Örnek veri çerçevesi: içinde

df <- data.frame(
     x=c("a","b","c","d"), 
     a=c(1,1,1,1), 
     b=c(1,1,1,NA), 
     c=c(1,1,NA,NA), 
     d=c(1,NA,NA,NA))  
df 

Sonuçlar:

x a b c d 
1 a 1 1 1 1 
2 b 1 1 1 NA 
3 c 1 1 NA NA 
4 d 1 NA NA NA 

Ama istiyorum göstermek için:

x a b c d 
1 a 1 1 1 1 
2 b 1 1 1 
3 c 1 1 
4 d 1 
+3

Uyarı: ne siz ne de okuyucularınızın nasıl incelendiğinden emin olun g boş yerlerde "hiçbir şey yok" veya "sıfır" (Excel'in yaptığı gibi) var. Bu sadece yayın için ise, iyi; aksi halde dikkatli olun. –

cevap

7

Sen (bu teknik print.dist S3 yöntemde kullanılan)

cf <- format(dat) ## use format to set other options like digits, justify , ... 
cf[is.na(dat)] <- "" 
cf 
    x a b c d 
1 a 1 1 1 1 
2 b 1 1 1 
3 c 1 1  
4 d 1  
3

kullanabilirsiniz write.table:

write.table(dfr,sep="\t",col.names=NA,na="") 
""  "x"  "a"  "b"  "c"  "d" 
"1"  "a"  1  1  1  1 
"2"  "b"  1  1  1  
"3"  "c"  1  1    
"4"  "d"  1 
5

yoktur, ancak öncelikle bir matrise zorlamak zorunda "", eksik değerler yerine ...

print(as.matrix(df) , na.print = "" , quote = FALSE) 
    x a b c d 
[1,] a 1 1 1 1 
[2,] b 1 1 1 
[3,] c 1 1  
[4,] d 1 

Kırbaç Bunu yapmak için küçük bir işleve ...

İlgili konular