R 语言是一门主要用于统计计算和绘图的高级编程语言。这份 R 语言编码风格指南旨在让我们的 R代码更容易阅读、分享和检查。以下规则系与 Google 的 R 用户群体协同设计而成。


概要: R编码风格约定

文件命名: 以 .R (大写) 结尾

标识符命名: variable.name, FunctionName, kConstantName

单行长度: 不超过 80 个字符

缩进: 两个空格, 不使用制表符

空白

花括号: 前括号不折行写, 后括号独占一行

赋值符号: 使用 <-, 而非 =

分号: 不要用

总体布局和顺序

注释准则: 所有注释以 # 开始, 后接一个空格; 行内注释需要在 # 前加两个空格

函数的定义和调用

函数文档

示例函数

TODO 书写风格: TODO(您的用户名)

概要: R语言使用规则

attach: 避免使用

函数: 错误 (error) 应当使用 stop() 抛出

对象和方法: 尽可能避免使用 S4 对象和方法; 永远不要混用 S3 和 S4


1 表示和命名

文件命名

文件名应以 .R (大写) 结尾,文件名本身要有意义。

正例: predict_ad_revenue.R

反例: foo.R

标识符命名

在标识符中不要使用下划线 ( _ ) 或连字符 ( - )。标识符应根据如下惯例命名:

  • 变量名应使用点 ( .)
  • 分隔所有的小写字母或单词;
  • 函数名首字母大写,不用点分隔 (所含单词首字母大写)
  • 常数命名规则同函数,但需使用一个 k 开头。

variable.name

正例: avg.clicks

反例: avg_Clicks , avgClicks

FunctionName

正例: CalculateAvgClicks

反例: calculate_avg_clicks , calculateAvgClicks

函数命名应为动词或动词性短语.

例外: 当创建一个含类 (class) 属性的对象时,函数名 (也是constructor) 和类名 (class) 应当匹配(例如:lm)

kConstantName

2 语法

单行长度

最大单行长度为 80 个字符.

缩进

使用两个空格来缩进代码。永远不要使用制表符或混合使用二者。

例外: 当括号内发生折行时,所折行与括号内的第一个字符对齐。

空白

在所有二元操作符 (=, +, -, <-, 等等) 的两侧加上空格。

例外: 在函数调用中传递参数时 = 两边的空格可加可不加。

不可在逗号前加空格,逗号后总须加空格

正例:

tabPrior <- table(df[df$daysFromOpt < , "campaignid"])
total <- sum(x[, ])
total <- sum(x[, ])

反例:

在前括号前加一个空格,函数调用时除外

正例: if (debug)

反例: if(debug)

多加空格

(即,在行内使用多于一个空格) 也是可以的,如果这样做能够改善等号或箭头 (<-)的对齐效果.

不要向圆括号或方括号中的代码两侧加入空格

例外: 逗号后总须加空格.

正例:

if (debug)
x[, ]

反例:

if ( debug ) # debug 的两边不要加空格
x[,] # 需要在逗号后加一个空格

花括号

前括号永远不应该独占一行; 后括号应当总是独占一行. 您可以在代码块只含单个语句时省略花括号;但在处理这类单个语句时, 您必须 前后一致地 要么全部使用花括号, 或者全部不用花括号.

if (is.null(ylim)) {
ylim <- c(, 0.06)
}或 (不可混用)
if (is.null(ylim))
ylim <- c(, 0.06)总在新起的一行开始书写代码块的主体.

反例:

, 0.06)
, 0.06)}

赋值

使用 <- 进行赋值, 不用 = 赋值.

正例: x <- 5

反例: x = 5

分号

不要以分号结束一行, 也不要利用分号在同一行放多于一个命令. (分号是毫无必要的, 并且为了与其他Google编码风格指南保持一致, 此处同样略去.)

3 代码组织

总体布局和顺序

如果所有人都以相同顺序安排代码内容, 我们就可以更加轻松快速地阅读并理解他人的脚本了.

注释

版权声明注释

作者信息注释

文件描述注释, 包括程序的用途, 输入和输出

source() 和 library() 语句

函数定义

要执行的语句, 如果有的话 (例如, print, plot)

单元测试应在另一个名为 原始的文件名_unittest.R 的独立文件中进行.

注释准则

注释您的代码. 整行注释应以 # 后接一个空格开始.

行内短注释应在代码后接两个空格, #, 再接一个空格.

函数的定义和调用

函数定义应首先列出无默认值的参数, 然后再列出有默认值的参数.

函数定义和函数调用中, 允许每行写多个参数; 折行只允许在赋值语句外进行.

正例:

反例:

PredictCTR <- function(query, property, numDays, showPlot =TRUE)

理想情况下, 单元测试应该充当函数调用的样例 (对于包中的程序来说).

函数文档

函数在定义行下方都应当紧接一个注释区. 这些注释应当由如下内容组成: 此函数的一句话描述;

此函数的参数列表, 用 Args: 表示, 对每个参数的描述 (包括数据类型); 以及对于返回值的描述, 以

Returns: 表示. 这些注释应当描述得足够充分, 这样调用者无须阅读函数中的任何代码即可使用此函数.

示例函数

TODO 书写风格

编码时通篇使用一种一致的风格来书写 TODO.

TODO(您的用户名): 所要采取行动的明确描述

4 语言

Attach

使用 attach 造成错误的可能数不胜数. 避免使用它.

函数

错误 (error) 应当使用 stop() 抛出.

对象和方法

S 语言中有两套面向对象系统, S3 和 S4, 在 R 中这两套均可使用. S3 方法的可交互性更强,更加灵活, 反之, S4 方法更加正式和严格. (对这两套系统的说明, 参见 Thomas Lumley 的文章"Programmer's Niche: A Simple Class, in S3 and S4", 发表于 R News 4/1, 2004, 33 - 36 页: http://cran.rproject.org/doc/Rnews/Rnews_2004-1.pdf.)

这里推荐使用 S3 对象和方法, 除非您有很强烈的理由去使用 S4 对象和方法. 使用 S4对象的一个主要理由是在 C++ 代码中直接使用对象. 使用一个 S4 泛型/方法的主要理由是对双参数的分发.避免混用 S3 和 S4: S4 方法会忽略 S3 中的继承, 反之亦然.

例外

除非有不去这样做的好理由, 否则应当遵循以上描述的编码惯例.

例外包括遗留代码的维护和对第三方代码的修改.

5 结语

遵守常识, 前后一致.

如果您在编辑现有代码, 花几分钟看看代码的上下文并弄清它的风格. 如果其他人在 if语句周围使用了空格, 那您也应该这样做. 如果他们的注释是用星号组成的小盒子围起来的,那您也要这样写。

遵循编码风格准则的意义在于, 人们相当于有了一个编程的通用词汇表, 于是人们可以专注于您在说什么, 而不是您是怎么说的. 我们在这里提供全局的编码风格规则以便人们了解这些词汇,但局部风格也很重要. 如果您加入文件中的代码看起来和周围的已有代码截然不同,那么代码阅读者的阅读节奏就会被破坏. 尽量避免这样做. OK, 关于如何写代码已经写得够多了;代码本身要有趣的多. 编码愉快!

参考文献

R语言编码惯例

http://www.maths.lth.se/help/R/RCC/

本文链接:

http://www.cnblogs.com/homewch/p/5865937.html

R 语言编码风格指南的更多相关文章

  1. 来自 Google 的 R 语言编码风格指南

    来自 Google 的 R 语言编码风格指南R 语言是一门主要用于统计计算和绘图的高级编程语言. 这份 R 语言编码风格指南旨在让我们的 R 代码更容易阅读.分享和检查. 以下规则系与 Google ...

  2. Python PEP-8编码风格指南中文版

    #PEP 8 – Python编码风格指南 PEP: 8 Title: Style Guide for Python Code Author: Guido van Rossum , Barry War ...

  3. (转)PEP 8——Python编码风格指南

    PEP 8——Python编码风格指南标签(空格分隔): Python PEP8 编码规范原文:https://lizhe2004.gitbooks.io/code-style-guideline-c ...

  4. Objective-C 编码风格指南

    本文转自:[Objective-C 编码风格指南 | www.samirchen.com][2] ## 背景 保证自己的代码遵循团队统一的编码规范是一个码农的基本节操,能够进入一个有统一编码规范的团队 ...

  5. PEP8中文版 -- Python编码风格指南

    Python部落组织翻译, 禁止转载 目录      缩进      制表符还是空格?      行的最大长度      空行      源文件编码      导入      无法忍受的      其 ...

  6. JavaScript编码风格指南(中文版)

    前言: 程序语言的编码风格对于一个长期维护的软件非常重要,特别是在团队协作中.如果一个团队使用统一规范的编码分风格,可以提高团队的协作水平和工作效率.编程风格指南的核心是基本的格式化规则,这些规则决定 ...

  7. Python 编码风格指南

    原文:http://python.jobbole.com/84618/ 本文超出 PEP8 的范畴以涵盖我认为优秀的 Python 风格.本文虽然坚持己见,却不偏执.不仅仅涉及语法.模块布局等问题,同 ...

  8. 《编写可维护的 Javascript》读书笔记(附录 A 部分):Javascript 编码风格指南(1)原始值

    记录一下比较有用的编码规范(该指南是基于 Java 语言编码规范和 Javascript 编程规范,同时结合作者 Nicholos Zakas 的个人经验和喜好). 一些关于格式(包括缩进.行的长度. ...

  9. 【翻译】EXTJS 编码风格指南与实例

    原文:EXTJS Code Style Guide with examples Ext JS风格指南: 熟知的且易于学习 快速开发,易于调试,轻松部署 组织良好.可扩展和可维护 Ext JS应用程序的 ...

随机推荐

  1. Python Day1

    一.安装python windows 1.下载安装包 https://www.python.org/downloads/ 2.安装 默认安装到C盘下 3.配置环境变量 右键计算机属性---高级系统设置 ...

  2. 怎样学习Java

    JAVA自学之路 一:学会选择 ,当你要走向社会的时候,就不要再把自己当成学生,不要把自己的将来交给别人,学会运用自己的眼睛去观察,去了解这个世界吧. 我讲一个通过招聘网站的观察方法: http:// ...

  3. morse code

    morse code,摩斯电码,是一种时通时断的信号代码,通过不同的排列顺序来表达不同的英文字母.数字和标点符号. 摩斯电码,是一种早期的数字化通信形式,但是它不同于现代只使用0和1两种状态的二进制代 ...

  4. Python之路【第二十篇】其他WEB框架

    WEB框架功能分析 WEB框架本质上,就是一个SOCKET Server WEB框架前面有WSGI或者是自己写的SOCKET,然后交给URL路由系统处理,然后交给某个函数或某个类,然后在模板里拿到模板 ...

  5. sqlpuls基本命令

    1.直接敲sqlplus并回车就是启动SQL*PLUS,输入user及password将使用户登陆到缺省的数据库.2.sqlplus user/password@SERVICE_NAME 将连接到指定 ...

  6. 进入OS前的两步之PendSV(任务切换)

    先了解下如何使用PendSV异常.(为何要使用PendSV而不是其他的异常,请参考<cortex-M3权威指南>) 1,如何设定PendSV优先级? NVIC_SYSPRI14 EQU 0 ...

  7. Android 基础篇(二)

    ADB进程 adb指令 adb install xxx.apk adb uninstall 包名 adb devices adb start-server adb kill-server adb sh ...

  8. Python 爬虫2

    import urllib.request import os import re import time 设置头文件 head={} head['User-Agent'] ='Mozilla/5.0 ...

  9. Ubuntu14.04 lamp环境 php 无法加载mcrypt扩展

    Ubuntu14.04中安装后的LAMP环境(http://www.cnblogs.com/daiyu/p/4380657.html)中没有加载:mcrypt扩展,后期再laravel5使用中发现报错 ...

  10. (zz)linux awk

    博文转载自http://www.cnblogs.com/ggjucheng/archive/2013/01/13/2858470.html 谢谢原作者.条理很清楚,由浅入深.敲了每一行命令,正确无误. ...