【问题标题】:Multiple colours for data points with scatterplot in RR中带有散点图的数据点的多种颜色
【发布时间】:2020-05-01 17:21:54
【问题描述】:

所以我的任务是基本上得到下图。 数据来自数据框,其中某些值已标记为 NA。 因此,我的代码如下:

> plot(temp,ozone,
+      xlab = "temperature",
+      ylab = "ozone",
+      col = ifelse(which(ozone>100), "red", "orange",),
+      pch = 17)

但是我现在收到一个错误:

"Error in ifelse(which(ozone > 100), "red", "orange", ) : 
  unused argument (alist())

如果有任何关于哪里出了问题的反馈/指示,我将不胜感激。 我以前也尝试过类似的东西:

highlevels <- which(ozone>100)
lowlevels <- which(ozone<100)
col = c("red","orange")[highlevels,lowlevels]

但显然这也不起作用......

【问题讨论】:

  • 你试过ozone而不是ozones吗?
  • 哇,没听懂 - 谢谢!可悲的是,错误仍然存​​在。

标签: r scatter-plot


【解决方案1】:

省略which 并将其包装在另一个ifelse 中是一种选择:

plot(temp, ozone,
     xlab = "temperature",
     ylab = "ozone",
     col = ifelse(ifelse(!is.na(ozone), ozone, 0) > 100, "red", "orange"),
     pch = 17)

否则,如果您使用这些库,tidyr::replace_nadplyr::coalesce 之类的函数可以为您提供帮助。

另一种选择是将所有变量子集到那些非缺失变量中。

另一个正在设置

col =  c("red", "orange")[(ozone > 100) + 1]

但这有点棘手。

【讨论】:

  • 谢谢大家!没想到这么小的一个错误,基本上可以毁掉整个代码:(
  • @AndersEllernBilgrau,我不明白你的编辑是如何工作的:[(ozone&gt;100)+1],这基本上是说所有 > 100 + 1 的东西都会是红色的吗?
  • @aislinx 不,(ozone &gt; 100) 是一个逻辑向量(可能带有 NA),并且将 1 添加到它会得到一个 1s、2s 和 NA 的向量,即 TRUE 和 @ 987654331@ 分别被视为10。然后使用一和二来对颜色的字符向量进行子集化。试试(c(1, 2, NA) &gt; 1) + 1 和它的一部分。所以这只是一些 hacky 子集。
  • 哦,好的!我不知道可以以这种方式使用子集。谢谢你的解释!
猜你喜欢
  • 1970-01-01
  • 2016-05-04
  • 1970-01-01
  • 1970-01-01
  • 2016-05-20
  • 2016-12-30
  • 1970-01-01
  • 1970-01-01
  • 2019-09-28
相关资源
最近更新 更多