R code on Google docs

后端 未结 4 1020
既然无缘
既然无缘 2021-02-10 02:47

I\'m aware that you can publish spreadsheets on Google docs and then import them in R. However, let\'s say I have a function or some code I want to read in R (like in the sourc

相关标签:
4条回答
  • 2021-02-10 03:17

    It is most easily done with Dropbox - see here http://thebiobucket.blogspot.co.at/2012/05/source-r-script-from-dropbox.html

    like so:

    source("http://dl.dropbox.com/s/c18lcwnnrodsevt/test_dropbox_source.R")
    

    But you can either do it with Googledocs, like here http://thebiobucket.blogspot.co.at/2011/11/how-to-run-r-scripts-directly-out-of.html#more

    library(RCurl)
    setwd(tempdir())
    destfile = "test_google_docs.txt"
    x = getBinaryURL("https://docs.google.com/uc?export=download&id=0B2wAunwURQNsMDViYzllMTMtNjllZS00ZTc4LTgzMzEtNDFjMWQ3MTUzYTRk", followlocation = TRUE, ssl.verifypeer = FALSE)
    writeBin(x, destfile, useBytes = TRUE)
    source(paste(tempdir(), "/test_google_docs.txt", sep = ""))
    
    0 讨论(0)
  • 2021-02-10 03:18

    I also think that the best way is to use github or dropbox. But using the RGoogleDocs and XML packages we can parse the code (I'm not very experienced) with XML parsing may be someone will have better code.

    ### require(devtools);dev_mode(TRUE, .libPaths()[1]);install_github("RGoogleDocs", "duncantl")
    require(RGoogleDocs) 
    require(XML)
    
    auth <- getGoogleAuth("dicko.ahmadou@gmail.com", "*********")
    
    con <- getGoogleDocsConnection(auth)
    
    mydoc <- getDocs(con)
    
    ## I put star for confidentiality
    ## Your doc is in 10th position
    names(mydoc)
    
    ##  [1] "*********"                                 
    ##  [2] "*********"                             
    ##  [3] "panel_tp_transferts"                                      
    ##  [4] "txint"                                                    
    ##  [5] "avortementsuivisen"                                       
    ##  [6] "Untitled Document"                                        
    ##  [7] "copie de villages_emprise10km"
    ##  [8] "AéroportBlaiseDiagne_AFDB.pdf"                            
    ##  [9] "strassen_eng.pdf"                                         
    ## [10] "R_script_CO2_emissions_airborne"  
    
    
    rcode <- mydoc[[10]]
    rcode <- getDocContent(rcode, con)
    ## remove Non break space in the document (there are plenty of them...)
    rcode <- gsub("&nbsp;", " ", rcode)
    rcode <- htmlParse(rcode, asText = TRUE)
    rcodecontent <- xpathApply(rcode, "/html//body//p//span")
    rcodecontent <- sapply(rcodecontent, function(x) unname(xmlSApply(x, xmlValue))
    

    Now we can save the code in a file

    ### save the script in my dropbox folder (dropbox is very easy to use...)
    cat(sapply(rcodecontent, function(x) paste(x, "\n")), 
           file = "/home/ahmadou/Dropbox/Public/code.R")
    
    ### retrieve the public link
    oldwd <- getwd()
    setwd("/home/ahmadou/Dropbox/Public")
    system('dropbox puburl code.R', intern = TRUE)
    [1] "https://dl.dropbox.com/u/8750577/code.R"
    
    setwd(oldw)
    

    Here is the link for the code

    0 讨论(0)
  • 2021-02-10 03:35

    I would suggest Github or something similar for this type of situation.

    Just a few of the reasons for recommending Github:

    • Version control
    • Code highlighting
    • Collaboration
    • Ability to develop and host an R package on Github that others can install in R using the devtools package
    • Simple URL scheme that makes it easy to use source() to load functions

    Once you have posted your function to Github, you can easily load it as follows:

    require(RCurl)
    baseURL = c("https://raw.github.com/--username--/--repo-name--/master/")
    source(textConnection(getURL(paste0(baseURL, "path-to-scripts/script-name.R"))))
    

    Of course, you can easily wrap that into a function instead of having to type it out in each R session, or try some of the options in the devtools package.

    If you do this a lot, you might want to learn to make an R package and host it on Github. If you only need to do this once in a while, you might consider using "github:gist" instead. Each "gist" is assigned a numeric ID that can then easily be sourced using source_gist() from the devtools package as follows:

    source_gist("gist-id-number")
    

    Pretty hard to beat that, but you do have to make note of the ID numbers for your functions, or put all of your functions in one file and memorize one ID number...


    The reason I wouldn't recommend something like Google Docs to write your code is that it is generally a terrible idea to use "word processor" type software for such purposes as they might introduce hidden characters that would make your file difficult to source. Furthermore, the URL to the plain text version is a very obscure one that you won't be able to remember....

    Incidentally, it is possible to get the "txt" version of the file you've linked to in your post, but I'm not able to source() it--I have to open it in a text editor and copy and paste it into R. This is because of the file encoding which appears to be "UTF-8 (with BOM)". Anyone out there have tips on how to deal with that?

    0 讨论(0)
  • 2021-02-10 03:38

    There is an Package RGoogleDocs which supports uploading and downloading files. Once the file is downloaded, you can use source to read it.

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