在R脚本语言中,如何编写行文本,例如,下面两行

Hello
World

到一个名为output.txt的文件?


当前回答

我将使用cat()命令,如下例所示:

> cat("Hello",file="outfile.txt",sep="\n")
> cat("World",file="outfile.txt",append=TRUE)

然后,您可以使用R with查看结果

> file.show("outfile.txt")
hello
world

其他回答

为了完善可能性,你可以使用writeLines()和sink(),如果你想:

> sink("tempsink", type="output")
> writeLines("Hello\nWorld")
> sink()
> file.show("tempsink", delete.file=TRUE)
Hello
World

对我来说,使用print()似乎总是最直观的,但如果你这样做,输出将不是你想要的:

...
> print("Hello\nWorld")
...
[1] "Hello\nWorld"

你可以用一个语句来做

cat("hello","world",file="output.txt",sep="\n",append=TRUE)

我将使用cat()命令,如下例所示:

> cat("Hello",file="outfile.txt",sep="\n")
> cat("World",file="outfile.txt",append=TRUE)

然后,您可以使用R with查看结果

> file.show("outfile.txt")
hello
world

根据最佳答案:

file <- file("test.txt")
writeLines(yourObject, file)
close(file)

注意,youobject需要是字符串格式;如果需要,使用as.character()进行转换。

但是对于每次保存尝试来说,输入太多了。让我们在RStudio中创建一个代码片段。

在Global Options >> Code >> Snippet中,键入以下内容:

snippet wfile
    file <- file(${1:filename})
    writeLines(${2:yourObject}, file)
    close(file)

然后,在编码过程中,输入wfile并按Tab键。

简单的write.table()怎么样?

text = c("Hello", "World")
write.table(text, file = "output.txt", col.names = F, row.names = F, quote = F)

参数col.names = FALSE和row.names = FALSE确保排除txt中的行名和列名,参数quote = FALSE排除txt中每行开头和结尾的引号。 要将数据读入,可以使用text = readLines("output.txt")。