- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我目前正在根据实验数据制作条形图。似乎当我在连续的 x 尺度上绘制条形时,条形之间的间距/间隙不均匀。我认为这是因为缺少特定时间的数据点,但是有什么方法可以使差距均匀吗?
我使用以下简单代码来绘制此图:
dataset_test %>%
ggplot(aes(time, normalized_gfp)) +
geom_bar(stat="identity", size=.1, fill="green", color="green", alpha=.4)
gfp485 条形图示例:
[ ]
数据示例的头部(在本例中我绘制了 gfp485,但我将在最终图中的顶部绘制“od”)
> head(dataset,20)
time media gfp485 od
1 0.24 IO+CasA_gfp 0.3333333 0.006666667
2 2.64 IO+CasA_gfp -4.3333333 0.003333333
3 5.04 IO+CasA_gfp 5.6666667 0.003333333
4 7.20 IO+CasA_gfp 10.6666667 0.010000000
5 9.60 IO+CasA_gfp 6.3333333 0.023333333
6 12.00 IO+CasA_gfp 358.3333333 0.060000000
7 14.40 IO+CasA_gfp 1216.6666667 0.086666667
8 16.56 IO+CasA_gfp 2422.6666667 0.100000000
9 18.96 IO+CasA_gfp 3550.3333333 0.113333333
10 21.36 IO+CasA_gfp 4770.3333333 0.140000000
11 23.52 IO+CasA_gfp 5671.3333333 NA
12 25.92 IO+CasA_gfp 6491.0000000 0.166666667
13 28.32 IO+CasA_gfp 6862.6666667 0.176666667
14 30.72 IO+CasA_gfp 7028.3333333 0.166666667
15 32.88 IO+CasA_gfp 6704.0000000 0.166666667
16 35.28 IO+CasA_gfp 6480.3333333 0.153333333
17 37.68 IO+CasA_gfp 6312.6666667 0.150000000
18 40.08 IO+CasA_gfp 6171.0000000 0.143333333
19 42.24 IO+CasA_gfp 5945.3333333 0.136666667
20 44.64 IO+CasA_gfp 5889.6666667 0.123333333
提前非常感谢您:))
最佳答案
即使没有缺失值,我们也可以看到示例数据中条形的间距不均匀:
library(ggplot2)
ggplot(dataset_test, aes(time, gfp485)) +
geom_col(size= .1, fill = "green", color = "green", alpha = 0.4)
其原因是您的观察在时间上分布不均匀。如果我们检查连续时间值之间的差异,我们会发现它们并不完全相同:
diff(dataset_test$time)
#> [1] 2.40 2.40 2.16 2.40 2.40 2.40 2.16 2.40 2.40 2.16 2.40 2.40 2.40 2.16
#> [15] 2.40 2.40 2.40 2.16 2.40
如果您准备更改实际数据以获得更漂亮的绘图,但保持总体时间等于原始时间,您可以这样做:
ggplot(dataset_test,
aes(x = min(time) + seq(0, by = mean(diff(time)), length = length(time)),
y = gfp485)) +
geom_col(size= .1, fill = "green", color = "green", alpha = 0.4) +
labs(x = "time")
但是,如果您有不等间隔的时间数据和 y 轴上的连续变量,那么使用 geom_area
会更诚实(并且我认为更具视觉吸引力):
ggplot(dataset_test, aes(time, gfp485)) +
geom_area(fill = "#90d850", color = "#266825", alpha = 0.4, size = 0.5) +
theme_minimal(base_size = 16) +
theme(plot.background = element_rect(fill = "#fafaf4", color = NA))
创建于 2022 年 10 月 11 日 reprex v2.0.2
关于r - 如何避免 ggplot2 条形图中条形之间的间距不均匀?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/74034420/
这个问题在这里已经有了答案: Why should there be spaces around '[' and ']' in Bash? (4 个回答) 3年前关闭。 作为初学者,我没有在任何地方找
我有一个程序,我在其中输入 Java 程序来检查输入的字符串是否为回文。我有 2 个问题正在发生,我似乎一辈子都无法解决。 我已经输入了代码,这样它会告诉我它是否是一个回文,当所有小写字母不涉及空格时
table { border: 0; padding: 0; border-collapse: collapse;
我有 10 个单元格,其中第 6 个单元格的宽度必须与其他单元格不同。我试图在流委托(delegate)方法中更改它。但是从第 7 个单元格到第 10 个单元格的间距出了点问题。 func coll
我只是希望将这些新闻发布很好地隔开,以便在每次发布之间留出空隙。我在下面附上了一张图片来解释。我试图增加下面的填充,但这没有用。感谢您的帮助 .headline { position: absolut
如何使用 css 删除表格结构中烦人的单元格间距和/或填充?如果解决方案在 IE7-9、Firefox 和 Chrome 中有效,请加倍支持! 为什么CSS这么难!真让人抓狂! 最佳答案 通常,在该表
我在我正在使用的网站上设置了按钮。我想在按钮外创建一个 2px 的边框,有一点间距。请参见设计图像。 我可以创建边框,但不能创建边框之外的间距。这是当前的开发站点。按钮是第一个图形。 到目前为止我已经
我正在网站上生成元素符号列表(通过使用 jquery 自动完成功能)和我在网站中使用响应式网页设计。 我想在每个列表项后留一个空格。为此,我添加了以下 CSS: li { margin-b
我在格式化我的 HTML 页面时遇到困难。 正如您从源代码中看到的那样,它是一个表格,其中每一行都包含由我的网络应用程序动态填充的格式化记录列表。如果其中一列有空值,我想保留行的格式,所以我基本上应该
我一直致力于设计一个具有三个链接的跨移动设备宽度的设计。我不明白为什么我不能得到正确的间距。什么看起来不对劲? 设计如下: 下面是编码版本的样子: 这是我的 CSS: .b-nav-Wrapper {
我需要在 matplotlib 中生成一大堆垂直堆叠的图。结果将使用 savefig 保存并在网页上查看,所以我不在乎最终图像有多高,只要子图间隔开,这样它们就不会重叠。 无论我允许这个数字有多大,子
我需要在 matplotlib 中生成一大堆垂直堆叠的图。结果将使用 savefig 保存并在网页上查看,所以我不在乎最终图像有多高,只要子图之间有间距,不重叠即可。 无论我允许图有多大,子图似乎总是
是否可以在 BorderPane 上设置节点之间的间距? ? Swing 等效项将是 BorderLayout 上的 hgap 和 vgap . 我在文档中没有找到任何内容,我能想到的唯一可行的解
我有一个基于日历的应用 我希望用户能够通过捏合来放大和缩小日历。这是我的代码: let p = UIPinchGestureRecognizer(target: self, action: #sele
我在为 Android 编写一段代码时遇到问题。我使用的是eclipse开发环境。我想要完成的是将一周中的日子均匀地分布在表格的第一行(有六行)。我不知道如何才能使这些单词真正散开,而不是仅仅粘在一起
我有一个基于日历的应用 我希望用户能够通过捏合来放大和缩小日历。这是我的代码: let p = UIPinchGestureRecognizer(target: self, action: #sele
我该怎么做才能对齐此代码中的所有列?这是正确的还是......? import urllib.request from re import findall def determinarLlegadas
当使用垂直对齐的 BoxLayout 时,如何阻止组件随着包含的 JFrame 的增长而扩展,从而在底部留下额外的空间?我尝试了不同的布局,但很快就变得一团糟。我还尝试在面板底部添加胶水,但布局管理器
我正在尝试制作 cout #include int main() { std::cout << setw(4) << 1 << setw(4) << 2 << std::endl; } 输出
使用示例 http://developer.android.com/guide/tutorials/views/hello-tabwidget.html通过向布局添加 HorizontalScro
我是一名优秀的程序员,十分优秀!