3 回答
TA贡献1805条经验 获得超9个赞
(这是我对如何写一个可重复的例子的建议。我试图让它变短但很甜)
如何编写可重现的示例。
如果您提供可重现的示例,您最有可能获得R问题的良好帮助。一个可重现的示例允许其他人通过复制和粘贴R代码来重新创建您的问题。
为了使您的示例可重现,您需要包含四件事:所需的包,数据,代码和R环境的描述。
应该在脚本的顶部加载包,因此很容易看到示例需要哪些包。
在电子邮件或Stack Overflow问题中包含数据的最简单方法是使用
dput()
生成R代码来重新创建它。例如,要mtcars
在R中重新创建数据集,我将执行以下步骤:dput(mtcars)
在R中运行复制输出
在我可重现的脚本中,键入
mtcars <-
然后粘贴。花一点时间确保您的代码易于其他人阅读:
确保你已经使用了空格,你的变量名称简洁,但信息丰富
使用注释来指出问题所在
尽力删除与问题无关的所有内容。
代码越短,理解起来就越容易。sessionInfo()
在代码中包含注释的输出。这总结了您的R环境,并且可以轻松检查您是否使用了过时的软件包。
你可以通过启动一个新的R会话并粘贴你的脚本来检查你是否真的做了一个可重现的例子。
在将所有代码放入电子邮件之前,请考虑将其放在Gist github上。它将为您的代码提供良好的语法突出显示,您不必担心电子邮件系统会破坏任何内容。
TA贡献1858条经验 获得超8个赞
就个人而言,我更喜欢“一个”衬里。一些事情:
my.df <- data.frame(col1 = sample(c(1,2), 10, replace = TRUE), col2 = as.factor(sample(10)), col3 = letters[1:10], col4 = sample(c(TRUE, FALSE), 10, replace = TRUE))my.list <- list(list1 = my.df, list2 = my.df[3], list3 = letters)
数据结构应该模仿作者的问题而不是确切的逐字结构。当变量不覆盖我自己的变量或上帝禁止,函数(如df
)时,我真的很感激。
或者,可以剪切几个角并指向预先存在的数据集,例如:
library(vegan)data(varespec)ord <- metaMDS(varespec)
不要忘记提及您可能正在使用的任何特殊包装。
如果你想在更大的物体上展示一些东西,你可以试试
my.df2 <- data.frame(a = sample(10e6), b = sample(letters, 10e6, replace = TRUE))
如果您通过raster
包处理空间数据,则可以生成一些随机数据。在包装插图中可以找到很多例子,但这里有一个小金块。
library(raster)r1 <- r2 <- r3 <- raster(nrow=10, ncol=10)values(r1) <- runif(ncell(r1))values(r2) <- runif(ncell(r2))values(r3) <- runif(ncell(r3))s <- stack(r1, r2, r3)
如果您需要实现的某些空间对象sp
,则可以通过“空间”包中的外部文件(如ESRI shapefile)获取一些数据集(请参阅任务视图中的空间视图)。
library(rgdal)ogrDrivers()dsn <- system.file("vectors", package = "rgdal")[1]ogrListLayers(dsn)ogrInfo(dsn=dsn, layer="cities")cities <- readOGR(dsn=dsn, layer="cities")
- 3 回答
- 0 关注
- 705 浏览
添加回答
举报