开发自己的R包(转)
R不必说,数据统计分析可视化的必备语言,R包开发的门槛比较低,所以现在随便一篇文章都会发表一个自己的R包,这样有好处(各种需求早有人帮你解决了)也有坏处(R包太多,混乱,新手上手较难)。作为生信工程师,日常就是查看别人写的R包,分析数据,然后借鉴、修改,根据自己的需求开发新的R包。
参考:
http://blog.fens.me/r-build-package/
Developing Packages with RStudio
To do:开发一个R包,部署到GitHub上(发paper的标准流程)
前言
R是一个世界范围开发者共同协作的产物,至2013年2月共计近5000个包可在互联网上自由下载。现在作为R的使用者,有朝一日也可以成为R的开发者,把我们自己的知识做成R包分享给世界。
今天我们简单介绍如何开发自己R包。
目录
- 系统环境
- vi中制作R包
- RStudio中制作R包
1. 系统环境
操作系统:Linux Ubuntu 12.04.2 LTS 64bit
R语言版本:R 3.0.1
~ uname -a
Linux conan-deskop 3.5.0-23-generic #35~precise1-Ubuntu SMP Fri Jan 25 17:13:26 UTC 2013 x86_64 x86_64 x86_64 GNU/Linux ~ cat /etc/issue
Ubuntu 12.04.2 LTS \n \l ~ R --version
R version 3.0.1 (2013-05-16) -- "Good Sport"
Copyright (C) 2013 The R Foundation for Statistical Computing
Platform: x86_64-pc-linux-gnu (64-bit) R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under the terms of the
GNU General Public License versions 2 or 3.
For more information about these matters see
http://www.gnu.org/licenses/.
2. vi中制作R包
创建目录:/home/conan/R/demo
~ mkdir /home/conan/R/demo
~ cd /home/conan/R/demo
新建R脚本sayHello.R
~ vi sayHello.R
sayHello<-function(name){
print(paste("Hello",name))
}
自定义一个sayHello的函数,将作为自定义包的第一个函数。
启动R程序
~ R #清空变量设置工作目录
rm(list=ls())
setwd("/home/conan/R/demo") #通过sayHello的脚本生成开发包的骨架
package.skeleton(name="sayHello",code_files="/home/conan/R/demo/sayHello.R")
Creating directories ...
Creating DESCRIPTION ...
Creating NAMESPACE ...
Creating Read-and-delete-me ...
Copying code files ...
Making help files ...
Done.
Further steps are described in './sayHello/Read-and-delete-me'. #退出R的客户端
q()
在当前目录生成sayHello目录
~ ls -l
drwxrwxr-x 4 conan conan 4096 8月 1 15:07 sayHello
-rw-rw-r-- 1 conan conan 59 8月 1 15:04 sayHello.R ~ ls -l sayHello
-rw-rw-r-- 1 conan conan 281 8月 1 15:07 DESCRIPTION
drwxrwxr-x 2 conan conan 4096 8月 1 15:07 man
-rw-rw-r-- 1 conan conan 31 8月 1 15:07 NAMESPACE
drwxrwxr-x 2 conan conan 4096 8月 1 15:07 R
-rw-rw-r-- 1 conan conan 420 8月 1 15:07 Read-and-delete-me ~ ls -l sayHello/man
-rw-rw-r-- 1 conan conan 1043 8月 1 15:07 sayHello-package.Rd
-rw-rw-r-- 1 conan conan 1278 8月 1 15:07 sayHello.Rd ~ ls -l sayHello/R
-rw-rw-r-- 1 conan conan 59 8月 1 15:07 sayHello.R
文件及目录解释:
- DESCRIPTION文件: 包描述文件
- NAMESPACE文件: 包的命名空间文件
- Read-and-delete-me文件: 说明文件,可以删除
- man目录: 存放函数的说明文件的目录
- R目录:存放源文件的目录
- man/sayHello.Rd: sayHello函数的说明文件,latex语法,用来生成PDF文档
- man/sayHello-package.Rd: sayHello包的说明文件,可以删除
编辑DESCRIPTION文件:
~ vi sayHello/DESCRIPTION
Package: sayHello
Type: Package
Title: R package demo for sayHello
LazyLoad: yes
Author: Dan Zhang
Maintainer: Dan Zhang
Description: This package provides a package demo
License: GPL
Version: 1.0
Date: 2013-07-31
Depends: R (>= 3.0.1)
</BSSPIRIT@GMAIL.COM>
编辑NAMESPACE文件:
~ vi sayHello/NAMESPACE
exportPattern("^[[:alpha:]]+")
编辑sayHello.Rd文件:
~ vi sayHello/man/sayHello.Rd
\name{sayHello}
\alias{sayHello}
\title{a sayHello function demo}
\description{
a sayHello function demo
}
\usage{
sayHello(name)
}
\arguments{
\item{name}{a word}
}
\details{
nothing
}
\value{
no return
}
\references{
nothing
}
\author{
Dan Zhang
}
\note{
nothing
}
\seealso{
nothing
}
\examples{
sayHello("world")
}
\keyword{ sayHello }
删除文件:
~ rm sayHello/Read-and-delete-me
~ rm sayHello/man/sayHello-package.Rd
打包sayHello
~ R CMD build sayHello
* checking for file ‘sayHello/DESCRIPTION’ ... OK
* preparing ‘sayHello’:
* checking DESCRIPTION meta-information ... OK
* checking for LF line-endings in source and make files
* checking for empty or unneeded directories
* building ‘sayHello_1.0.tar.gz’ ~ ls -l
drwxrwxr-x 4 conan conan 4096 8月 1 15:22 sayHello
-rw-r--r-- 1 conan conan 663 8月 1 15:24 sayHello_1.0.tar.gz
-rw-rw-r-- 1 conan conan 59 8月 1 15:04 sayHello.R
本地安装sayHello
~ R CMD INSTALL sayHello_1.0.tar.gz
* installing to library ‘/home/conan/R/x86_64-pc-linux-gnu-library/3.0’
* installing *source* package ‘sayHello’ ...
** R
** preparing package for lazy loading
** help
*** installing help indices
** building package indices
** testing if installed package can be loaded
* DONE (sayHello) ~ ls /home/conan/R/x86_64-pc-linux-gnu-library/3.0
bitops digest manipulate rstudio sayHello XML
sayHello包,已经在当前账号下进行安装
使用sayHello函数
~ R library(sayHello)
sayHello("Conan")
[1] "Hello Conan" #查看sayHello文档
?sayHello sayHello package:sayHello R Documentation a sayHello function demo Description:
a sayHello function demo
Usage:
sayHello(name)
Arguments:
name: a word
Details:
nothing
Value:
no return
Note:
nothing
Author(s):
Dan Zhang
References:
nothing
我们包已经成功制作完成!并在本地进行安装和使用!!
检查R包
如果要提交R包和CRAN,必须要执行check检查。如果有任何的error和warning都将不被通过。
退出R的客户端,回到命令行
先安装latex的依赖包(500mb+)
~ sudo apt-get install texlive
~ sudo apt-get install texlive-xetex
~ sudo apt-get install texlive-latex-base
~ sudo apt-get install texlive-fonts-extra
~ sudo apt-get install texlive-latex-recommended
~ sudo apt-get install texlive-fonts-recommended
执行check
~ R CMD check sayHello_1.0.tar.gz * using log directory ‘/home/conan/R/demo/sayHello.Rcheck’
* using R version 3.0.1 (2013-05-16)
* using platform: x86_64-pc-linux-gnu (64-bit)
* using session charset: UTF-8
* checking for file ‘sayHello/DESCRIPTION’ ... OK
* checking extension type ... Package
* this is package ‘sayHello’ version ‘1.0’
* checking package namespace information ... OK
* checking package dependencies ... OK
* checking if this is a source package ... OK
* checking if there is a namespace ... OK
* checking for executable files ... OK
* checking for hidden files and directories ... OK
* checking for portable file names ... OK
* checking for sufficient/correct file permissions ... OK
* checking whether package ‘sayHello’ can be installed ... OK
* checking installed package size ... OK
* checking package directory ... OK
* checking DESCRIPTION meta-information ... OK
* checking top-level files ... OK
* checking for left-over files ... OK
* checking index information ... OK
* checking package subdirectories ... OK
* checking R files for non-ASCII characters ... OK
* checking R files for syntax errors ... OK
* checking whether the package can be loaded ... OK
* checking whether the package can be loaded with stated dependencies ... OK
* checking whether the package can be unloaded cleanly ... OK
* checking whether the namespace can be loaded with stated dependencies ... OK
* checking whether the namespace can be unloaded cleanly ... OK
* checking loading without being on the library search path ... OK
* checking for unstated dependencies in R code ... OK
* checking S3 generic/method consistency ... OK
* checking replacement functions ... OK
* checking foreign function calls ... OK
* checking R code for possible problems ... OK
* checking Rd files ... OK
* checking Rd metadata ... OK
* checking Rd cross-references ... OK
* checking for missing documentation entries ... OK
* checking for code/documentation mismatches ... OK
* checking Rd \usage sections ... OK
* checking Rd contents ... OK
* checking for unstated dependencies in examples ... OK
* checking examples ... OK
* checking PDF version of manual ... WARNING
LaTeX errors when creating PDF version.
This typically indicates Rd problems.
* checking PDF version of manual without hyperrefs or index ... OK WARNING: There was 1 warning.
See
‘/home/conan/R/demo/sayHello.Rcheck/00check.log’
for details.
发现有一个警告,checking PDF version of manual ... WARNING。是latex生成pdf错误。
查检警告的debug日志
~ R CMD Rd2pdf sayHello_1.0.tar.gz
Converting Rd files to LaTeX ...
sayHello_1.0.tar.gz
Warning in readLines(f) :
incomplete final line found on 'sayHello_1.0.tar.gz'
Warning in parse_Rd("sayHello_1.0.tar.gz", encoding = "unknown", fragment = FALSE, :
sayHello_1.0.tar.gz:16: unexpected '}'
Warning: sayHello_1.0.tar.gz:1: All text must be in a section
Warning: sayHello_1.0.tar.gz:2: All text must be in a section
Warning: sayHello_1.0.tar.gz:3: All text must be in a section
Warning: sayHello_1.0.tar.gz:4: All text must be in a section
Warning: sayHello_1.0.tar.gz:5: All text must be in a section
Warning: sayHello_1.0.tar.gz:6: All text must be in a section
Warning: sayHello_1.0.tar.gz:7: All text must be in a section
Warning: sayHello_1.0.tar.gz:8: All text must be in a section
Warning: sayHello_1.0.tar.gz:9: All text must be in a section
Warning: sayHello_1.0.tar.gz:10: All text must be in a section
Warning: sayHello_1.0.tar.gz:11: All text must be in a section
Warning: sayHello_1.0.tar.gz:12: All text must be in a section
Warning: sayHello_1.0.tar.gz:15: All text must be in a section
Error : sayHello_1.0.tar.gz: Sections \title, and \name must exist and be unique in Rd files
求助:
Error : sayHello_1.0.tar.gz: Sections \title, and \name must exist and be unique in Rd files
这个问题我检查了好多次始终没有解决。请求帮助!!
问题解决:安装完整包
sudo apt-get install texlive-full
上传R包
当解决了上面的WARN就可以上传了。。。(待续)
卸载R包
remove.packages("sayHello")
Removing package from ‘/home/conan/R/x86_64-pc-linux-gnu-library/3.0’ ~ ls /home/conan/R/x86_64-pc-linux-gnu-library/3.0
bitops digest manipulate rstudio XML
3. RStudio中制作R包
RStudio Server的安装及配置,请参考:多人在线协作R开发RStudio Server
RStudio已经为我们准备了一个有界面的环境,方便我们制作R包。
- 创建一个工程sayHello
- 编辑DESCRIPTION
- 创建sayHello.R的脚本
- 编辑sayHello.Rd的文档
1). 创建一个工程sayHello
2). 编辑rstudio/sayHello/DESCRIPTION
Package: sayHello
Type: Package
Title: R package demo for sayHell
LazyLoad: yes
Author: Dan Zhang
Maintainer: Dan Zhang
Description: This package provides a package demo
License: GPL
Version: 1.0
Date: 2013-07-31
Depends: R (>= 3.0.1)
</BSSPIRIT@GMAIL.COM>
3). 编辑rstudio/sayHello/R/sayHello.R的脚本
sayHello<-function(name){
print(paste("Hi",name))
}
4). 编辑rstudio/sayHello/man/sayHello.Rd的文档
\name{sayHello}
\alias{sayHello}
\title{a sayHello function demo}
\description{
a sayHello function demo
}
\usage{
sayHello(name)
}
\arguments{
\item{name}{a word}
}
\details{
nothing
}
\value{
no return
}
\references{
nothing
}
\author{
Dan Zhang
}
\note{
nothing
}
\seealso{
nothing
}
\examples{
sayHello("world")
}
\keyword{ sayHello }
5). 执行build和reload
6). 执行check
在RStudio中可以更方便的进行R的开包,打包,检查等的过程。RStudio就是R的神器!
虽然还没有发布自己的R包,不过很快了!!有此想法已经多时了!!每一天加油!
开发自己的R包(转)的更多相关文章
- R 包
[下面列出每个步骤最有用的一些R包] .数据导入 以下R包主要用于数据导入和保存数据: feather:一种快速,轻量级的文件格式:在R和python上都可使用 readr:实现表格数据的快速导入 r ...
- 从Github上轻松安装R包—githubinstall包--转载
1.综述 越来越多的R包正在由世界上不同的人所创建,其中一部分原因是devtools包使得开发R包1变得更加简单.devtools包不仅让开发R包变得简单,而且用于分发R包. 当开发者发布一个R包的时 ...
- 工业级GBDT算法︱微软开源 的LightGBM(R包正在开发....)
看完一篇介绍文章后,第一个直觉就是这算法已经配得上工业级属性.日前看到微软已经公开了这一算法,而且已经发开python版本,本人觉得等hadoop+Spark这些平台配齐之后,就可以大规模宣传啦~如果 ...
- 标准化R包开发流程
3个武器: devtools:各种开发小工具的合集,让开发变得简单,非常实用 roxygens:通过注释的方式,生成文档,远离LaTex的烦恼 testthat:单元测试,让R包稳定.健壮.减少升级的 ...
- 【转】linux和windows下安装python集成开发环境及其python包
本系列分为两篇: 1.[转]windows和linux中搭建python集成开发环境IDE 2.[转]linux和windows下安装python集成开发环境及其python包 3.windows和l ...
- R(三): R包原理及安装
包(package)是多个函数的集合,常作为分享代码的基本单元,代码封装成包可以方便其他用户使用.越来越多的R包正在由世界上不同的人所创建并分发,这些分发的R包,可以从CRAN 或 github 上获 ...
- 高质量、处于持续更新的R包
本文在Creative Commons许可证下发布 自由软件的问题是开发人员没有稳定的资金来源支持,可能更新上做不到持续.经过考证和圈内朋友的帮助,现在把R包中高质量.持续更新的跟大数据事业相关的R包 ...
- 极简 R 包建立方法--转载
https://cosx.org/2013/11/building-r-packages-easily/ 最近想试一下捣腾一个 R 包出来,故参考了一些教程.现在看到的最好的就是谢益辉大大之前写过的开 ...
- 如何创建R包并将其发布在 CRAN / GitHub 上--转载
转载--https://www.analyticsvidhya.com/blog/2017/03/create-packages-r-cran-github/ 什么是 R 包?我开始创建 R 包的原因 ...
随机推荐
- OO课程第四次总结
终于来到了最后一次的OO作业,以博客作业的形式来终结也是极好的,回顾一下过去十六周自己的经历,感慨颇深. 测试和正确性论证 简单来说,测试的目的是将程序的代码做到全覆盖,从而确保每个分支都运行一遍,进 ...
- 一、数据库表中字段的增删改查,二、路由基础.三、有名无名分组.四、多app共存的路由分配.五、多app共存时模板冲突问题.六、创建app流程.七、路由分发.八、路由别名,九、名称空间.十、反向解析.十一、2.x新特性.十二、自定义转换器
一.数据库表中字段的增删改查 ''' 直接在modules中对字段进行增删改查 然后在tools下点击Run manage.py Task执行makemigrations和migrate 注意在执行字 ...
- CEF3开发者系列之Cookies管理和共享
涉及网页登录相关的技术,Cookies肯定是忽略不了的.由于项目的需要,要做一个双核的产品.双核间切换会涉及到登录状态的问题,共享Cookies是一个很好的方案.既然涉及到共享cookies,那么读取 ...
- 【Python044--魔法方法:简单定制】
一.简单定制 基本要求: -- 定制一个计时器的类 -- start和stop代表开始计时和停止计时 -- 假设计时器对象t1,print(t1)和直接调用t1均显示结果 -- 当计时器未启动或停止计 ...
- Python3 tkinter基础 Frame bind 鼠标移动事件 实时显示鼠标的位置
Python : 3.7.0 OS : Ubuntu 18.04.1 LTS IDE : PyCharm 2018.2.4 Conda ...
- 修改userdata的分区大小【转】
本文转载自:https://blog.csdn.net/mike8825/article/details/49833833 版权声明:本文为博主原创文章,未经博主允许不得转载. https:// ...
- linux内核中的hisi_sas是什么?
答: 是一个HISILICON SAS 控制器驱动(HISILICON SAS controller driver)
- (转) RNN models for image generation
RNN models for image generation MARCH 3, 2017 Today we’re looking at the remaining papers from the ...
- 在Vue的构造器里我们写一个add方法,然后我们用实例的方法调用它
html <div id="app"> <div>{{message}}</div> </div> js var vm = new ...
- 4、lvs nat和dr类型演示
实战操作 LVS-NAT (应用场景:VIP是公网地址,DIP和RIP一般使用私网地址,NAT的主要目的是为了隐藏服务器) 核心要点: 1.DIP与各real server的RIP必须在同一个网段中 ...