繁体   English   中英

write.table列不与空格对齐

[英]write.table columns do not align with blanks

我有一个几乎空白的数据框,可以使用以下输入读取:

structure(list(var1 = c(1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L
), var2 = c(NA, NA, NA, NA, NA, NA, NA, NA, NA, NA), var3 = c(NA, 
NA, NA, NA, NA, NA, NA, NA, NA, NA), var4 = c(NA, NA, NA, NA, 
NA, NA, NA, NA, NA, NA), var5 = c(NA, NA, NA, NA, NA, NA, NA, 
NA, NA, NA), var6 = c(NA, NA, NA, NA, NA, NA, NA, NA, NA, NA), 
    var7 = c(1L, 1L, 1L, 1L, 1L, 2L, 2L, 2L, 2L, 2L), var8 = c(NA, 
    NA, NA, NA, NA, NA, NA, NA, NA, NA), var9 = c(NA, NA, NA, 
    NA, NA, NA, NA, NA, NA, NA), var10 = c(NA, NA, NA, NA, NA, 
    NA, NA, NA, NA, NA)), .Names = c("var1", "var2", "var3", 
"var4", "var5", "var6", "var7", "var8", "var9", "var10"), row.names = c(NA, 
10L), class = "data.frame")

我想将其写入TXT文件,看起来一切write.xlsx正确格式化,并且可以在Excel中轻松打开(我知道write.xlsx ,并且它解决了这个问题,我希望文件采用txt格式)。

write.table(df3, file="test.txt", quote = FALSE, na = " \t", row.names = FALSE)

我尝试了此操作,但这些值未正确对齐:例如,应在var7下显示的值显示在var6 同样,尽管Excel设法将列读取为单独的列,但包含变量名称的标题行被读取为一个长向量。 是什么赋予了?

使用write.table(df3, file="test.txt", quote = FALSE, sep = "\\t", na="", row.names = FALSE)请注意,使用sep = "\\t"代替了na = " \\t"并设置na=""

如果我写:

write.table(df3, file="test.txt", quote = FALSE, sep="\t", row.names = FALSE, na="")

然后就可以了。 我遵循了Jilber的建议,即使用sep="\\t"并且还对na选项进行了此操作,否则NA将显示在文件中。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM