草庐IT

Rprofile -- 自定义你的R启动方式

正经昵称征集中 2023-10-12 原文

Rprofile 文件位于R安装目录下的library/base/R/Rprofile,没错,是在base包下面。

相当于配置文件的功能,打开之后可以看到预设了很多东西,比如:

.GlobalEnv <- globalenv()
T <- TRUE
F <- FALSE
options(scipen = 0)
options(stringsAsFactors = TRUE)

此外,有两个特殊的函数:.First.Last,顾名思义,分别是在R终端启动和结束时运行,默认貌似是没有的(让我想到了构造析构??)。

因此,用户可以在此文件自定个人偏好、常用函数、预设变量以及一些有趣的东西,接下来展示一些我添加的一些内容。

interactive

展示之前先解释一下interative函数的功能,它可以判断当前R是否处于交互环境,有些功能我们可能只在R交互运行时才会用到,比如欢迎结束语、某些包等等,这时候就可以使用这个函数来判断以决定是否导入这些额外的功能。

这样做在速度和逻辑性上都会有所提升。

启动/结束语

自定义.First.Last函数可以实现这个功能:

.First <- function(){

    # wellcome
    if(interactive())
        cat(paste0("Hi ", Sys.info()[["user"]], ", wellcome to R!\n"))
}

以及:

.Last <- function(){
    if(interactive())
        cat("See you next time!\n")
}

自动加载包

这个功能看起来不错,其实当你进入R时运行search()时,你会发现已经有包已经被加载进来了:

> search()
[1] ".GlobalEnv"        "package:stats"     "package:graphics"
[4] "package:grDevices" "package:utils"     "package:datasets"
[7] "package:methods"   "Autoloads"         "package:base"

其实是Rprofile这个文件实现的功能:

local({dp <- Sys.getenv("R_DEFAULT_PACKAGES")
       if(identical(dp, "")) ## it fact methods is done first
           dp <- c("datasets", "utils", "grDevices", "graphics",
                   "stats", "methods")
       else if(identical(dp, "NULL")) dp <- character(0)
       else dp <- strsplit(dp, ",")[[1]]
       dp <- sub("[[:blank:]]*([[:alnum:]]+)", "\\1", dp) # strip whitespace
       options(defaultPackages = dp)
    })


.First.sys <- function()
{
    for(pkg in getOption("defaultPackages")) {
        res <- require(pkg, quietly = TRUE, warn.conflicts = FALSE,
                       character.only = TRUE)
        if(!res)
            warning(gettextf('package %s in options("defaultPackages") was not found', sQuote(pkg)),
                    call. = FALSE, domain = NA)
    }
}

可以看出自动加载了"datasets", "utils", "grDevices", "graphics", "stats", "methods"这些包,因此我们往里面加入其他的包名,这样就可以在R启动时自动自动加载了。

但是建议最好不要在原始内容上修改,而是单独写在.First函数里,比如我们想自动加载ggplot2这个包,可以这样做:

.First <- function(){

    suppressPackageStartupMessages(require("ggplot2", quietly = TRUE, warn.conflicts = FALSE, character.only = TRUE))
}

另外,有的包只需要在交互使用时才需要载入,比如用于彩色话屏幕输出的colorout包,这时也需要用到interactive函数:

if(interactive())
    if(Sys.getenv("TERM") == "xterm-256color")
        library("colorout")

colorout安装:

git clone https://github.com/jalvesaq/colorout.git
R CMD INSTALL colorout

但是需要权衡是否真正需要自动载入某些包,因为这意味着启动R需要消耗更多的时间。

自定义函数

自动source自己编写的函数:

source("my_functions.R")

设置镜像

options(BioC_mirror="https://mirrors.tuna.tsinghua.edu.cn/bioconductor")
options(repos="https://mirrors.tuna.tsinghua.edu.cn/CRAN/")

其他设置

options(stringsAsFactors = FALSE) # 不自动将string转换为Factor
# options(scipen = 999, digits = 6) # 不用科学计数法显示,保留6位有效数字,这个还是使用默认的吧,有时候还是挺有用的
options(max.print = 99) # 限制最大打印行数,打印99999那么多行干嘛哟!
options("width" = 100) # 设置每行最大显示字符个数,当你屏幕比较大时或许有用
options(continue = " ") # 换行输入时以空格开头,默认是+,当你选择粘贴时非常有用
options(warn = 2, error = recover) # 据说提醒和报错方式更友好,遇到了再看效果把,默认: options(warn=0, error=NULL)

See more: ?options or The options mechanism in R.

汇总

最后把这些代码整合一起,并放到Rprofile文件内容的最后以覆盖前面的预设:

########## my set
.First <- function(){
    cat(R.version.string, "\n") # 打印R版本
    loadp <- function(...){
        pkgs = as.character(substitute(list(...)))[-1]
        suppressMessages(for(pkg in pkgs) require(pkg, character.only = TRUE))
    }
    loadp(colorout) # 可续写

    if(interactive()){

        cat(paste0("Hi ", Sys.info()[["user"]], ", wellcome to R!\n"))
        if(Sys.getenv("TERM") == "xterm-256color")
          library("colorout")
    }

    options(BioC_mirror="https://mirrors.tuna.tsinghua.edu.cn/bioconductor")
    options(repos="https://mirrors.tuna.tsinghua.edu.cn/CRAN/")
    options(stringsAsFactors = FALSE) # 不自动将string转换为Factor
    # options(scipen = 999, digits = 6) # 不用科学计数法显示,保留6位有效数字,这个还是使用默认的吧,有时候还是挺有用的
    options(max.print = 999) # 限制最大打印行数/项,打印99999那么多行干嘛哟!
    # options("width" = 100) # 设置每行最大显示字符个数,当你屏幕比较大时或许有用
    options(continue = " ") # 换行输入时以空格开头,默认是+,当你选择粘贴时非常有用
    # options(warn = 2) # 据说提醒方式更友好,遇到了再看效果把,默认: options(warn=0, error=NULL)。更:千万别这样设,不痛不痒的warning 也会转成 error,wdnmd

    # source and library
    source("~/.yyds")
    library("yyds")
}

.Last <- function(){
    if(interactive())
        cat("See you next time!\n")
}
##########

上面有个loadp函数也赠送给大家,可以同时载入多个包,包名可以不加引号,功能类似某包的一个函数:

loadp(ggplot2, reshape2, GenomicRanges)

如果以后还有更多有趣的东西再补充~

有关Rprofile -- 自定义你的R启动方式的更多相关文章

  1. ruby - Facter::Util::Uptime:Module 的未定义方法 get_uptime (NoMethodError) - 2

    我正在尝试设置一个puppet节点,但ruby​​gems似乎不正常。如果我通过它自己的二进制文件(/usr/lib/ruby/gems/1.8/gems/facter-1.5.8/bin/facter)在cli上运行facter,它工作正常,但如果我通过由ruby​​gems(/usr/bin/facter)安装的二进制文件,它抛出:/usr/lib/ruby/1.8/facter/uptime.rb:11:undefinedmethod`get_uptime'forFacter::Util::Uptime:Module(NoMethodError)from/usr/lib/ruby

  2. ruby - 如何以所有可能的方式将字符串拆分为长度最多为 3 的连续子字符串? - 2

    我试图获取一个长度在1到10之间的字符串,并输出将字符串分解为大小为1、2或3的连续子字符串的所有可能方式。例如:输入:123456将整数分割成单个字符,然后继续查找组合。该代码将返回以下所有数组。[1,2,3,4,5,6][12,3,4,5,6][1,23,4,5,6][1,2,34,5,6][1,2,3,45,6][1,2,3,4,56][12,34,5,6][12,3,45,6][12,3,4,56][1,23,45,6][1,2,34,56][1,23,4,56][12,34,56][123,4,5,6][1,234,5,6][1,2,345,6][1,2,3,456][123

  3. ruby - 解析 RDFa、微数据等的最佳方式是什么,使用统一的模式/词汇(例如 schema.org)存储和显示信息 - 2

    我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i

  4. ruby-on-rails - Rails 3.2.1 中 ActionMailer 中的未定义方法 'default_content_type=' - 2

    我在我的项目中添加了一个系统来重置用户密码并通过电子邮件将密码发送给他,以防他忘记密码。昨天它运行良好(当我实现它时)。当我今天尝试启动服务器时,出现以下错误。=>BootingWEBrick=>Rails3.2.1applicationstartingindevelopmentonhttp://0.0.0.0:3000=>Callwith-dtodetach=>Ctrl-CtoshutdownserverExiting/Users/vinayshenoy/.rvm/gems/ruby-1.9.3-p0/gems/actionmailer-3.2.1/lib/action_mailer

  5. ruby-on-rails - form_for 中不在模型中的自定义字段 - 2

    我想向我的Controller传递一个参数,它是一个简单的复选框,但我不知道如何在模型的form_for中引入它,这是我的观点:{:id=>'go_finance'}do|f|%>Transferirde:para:Entrada:"input",:placeholder=>"Quantofoiganho?"%>Saída:"output",:placeholder=>"Quantofoigasto?"%>Nota:我想做一个额外的复选框,但我该怎么做,模型中没有一个对象,而是一个要检查的对象,以便在Controller中创建一个ifelse,如果没有检查,请帮助我,非常感谢,谢谢

  6. ruby - 主要 :Object when running build from sublime 的未定义方法 `require_relative' - 2

    我已经从我的命令行中获得了一切,所以我可以运行rubymyfile并且它可以正常工作。但是当我尝试从sublime中运行它时,我得到了undefinedmethod`require_relative'formain:Object有人知道我的sublime设置中缺少什么吗?我正在使用OSX并安装了rvm。 最佳答案 或者,您可以只使用“require”,它应该可以正常工作。我认为“require_relative”仅适用于ruby​​1.9+ 关于ruby-主要:Objectwhenrun

  7. ruby-on-rails - 启动 Rails 服务器时 ImageMagick 的警告 - 2

    最近,当我启动我的Rails服务器时,我收到了一长串警告。虽然它不影响我的应用程序,但我想知道如何解决这些警告。我的估计是imagemagick以某种方式被调用了两次?当我在警告前后检查我的git日志时。我想知道如何解决这个问题。-bcrypt-ruby(3.1.2)-better_errors(1.0.1)+bcrypt(3.1.7)+bcrypt-ruby(3.1.5)-bcrypt(>=3.1.3)+better_errors(1.1.0)bcrypt和imagemagick有关系吗?/Users/rbchris/.rbenv/versions/2.0.0-p247/lib/ru

  8. ruby - 在 Ruby 中有条件地定义函数 - 2

    我有一些代码在几个不同的位置之一运行:作为具有调试输出的命令行工具,作为不接受任何输出的更大程序的一部分,以及在Rails环境中。有时我需要根据代码的位置对代码进行细微的更改,我意识到以下样式似乎可行:print"Testingnestedfunctionsdefined\n"CLI=trueifCLIdeftest_printprint"CommandLineVersion\n"endelsedeftest_printprint"ReleaseVersion\n"endendtest_print()这导致:TestingnestedfunctionsdefinedCommandLin

  9. ruby - 定义方法参数的条件 - 2

    我有一个只接受一个参数的方法:defmy_method(number)end如果使用number调用方法,我该如何引发错误??通常,我如何定义方法参数的条件?比如我想在调用的时候报错:my_method(1) 最佳答案 您可以添加guard在函数的开头,如果参数无效则引发异常。例如:defmy_method(number)failArgumentError,"Inputshouldbegreaterthanorequalto2"ifnumbereputse.messageend#=>Inputshouldbegreaterthano

  10. ruby - 如何在 Grape 中定义哈希数组? - 2

    我使用Ember作为我的前端和GrapeAPI来为我的API提供服务。前端发送类似:{"service"=>{"name"=>"Name","duration"=>"30","user"=>nil,"organization"=>"org","category"=>nil,"description"=>"description","disabled"=>true,"color"=>nil,"availabilities"=>[{"day"=>"Saturday","enabled"=>false,"timeSlots"=>[{"startAt"=>"09:00AM","endAt"=>

随机推荐