How to solve “clipboard buffer is full and output lost” error in R running in Windows?

前端 未结 2 858
孤街浪徒
孤街浪徒 2021-01-30 22:49

I am trying to copy some data directly from R to the clipboard, in my Windows machine. I found in some sites that using file=\"clipboard\" would work. And it does, but for very

相关标签:
2条回答
  • 2021-01-30 23:20

    If you type ?connections you will find your answer.

    This is the relevant part:

    "When writing to the clipboard, the output is copied to the clipboard only when the connection is closed or flushed. There is a 32Kb limit on the text to be written to the clipboard. This can be raised by using e.g. file("clipboard-128") to give 128Kb."

    So, the solution is pretty straigthforward:

    df1 <- data.frame(x=runif(10000))
    write.table(df1, file="clipboard-16384", sep="\t", col.names=NA)
    

    Note that the number of Kb is just an example, so you can change it as you need (I put 2^14 that should be more than enough for your data set, but you can increase it even more. Not sure which is the hard limit, though. Maybe physical memory?)

    0 讨论(0)
  • 2021-01-30 23:25

    I like to use only the memory I need. So I let the object.size() function figure out what I need. In addition, I usually like to source a function that I like to use frequently.

    df1 <- data.frame(x=runif(10000))
    write.excel <- function(x,row.names=FALSE,col.names=TRUE,...) {
      write.table(x,file = paste0("clipboard-", object.size(x)),sep="\t",row.names=row.names,col.names=col.names,...)
    }
    
    write.excel(df1, FALSE, TRUE)
    

    It would probably be prudent to check the object.size is smaller than the memory.size. And let this thing fail if necessary.

    Hope this helps.

    0 讨论(0)
提交回复
热议问题