R语言论文插图模板第10期—正负柱状图

在之前的文章中,分享了R语言各式柱状 的绘制模板:

进一步,再来分享一种特殊的柱状图:正负柱状

先来看一下成品效果:

特别提示 :本期内容『数据+代码』已上传资源群中,加群的朋友请自行下载。有需要的朋友可以在同名公号阿昆的科研日常后台回复关键词【全家桶】查看加群方式


1. 数据准备

此部分主要是读取原始数据,并进行绘图前的预处理

复制代码
# 加载库library(readxl)library(tidyr)library(ggplot2)​# 修改工作路径# setwd("D:/R")​# 读取数据data <- read_excel("data_pnbar.xlsx")data$pos <- data$Anomaly10y >=0​# 将数据转换为数据框格式data <- as.data.frame(data)

2. 颜色定义

作图不配色就好比做菜不放盐,总让人感觉少些味道。

但颜色搭配比较考验个人审美,需要多加尝试。

这里直接使用TheBestColors配色工具中的SCI顶刊配色

复制代码
library(TheBestColors)map <- Best100(16)CC <- map[c(1,4)]

3.正负柱状图绘制

利用'geom_bar'函数,绘制初始正负柱状图

复制代码
p <- ggplot(data,aes(x=Year, y=Anomaly10y, fill=pos)) +  geom_bar(stat = "identity", width = 0.7, alpha = 1) +  scale_fill_manual(values = CC) +  geom_hline(yintercept=0,linewidth = 0.2)+  labs(x = 'Year', y = 'Anomaly10y')print(p)

4. 细节优化

为了插图的美观,对坐标轴细节等进行美化,并按期刊所需分辨率、格式输出图片。

复制代码
# 细节调整p+scale_x_continuous(breaks = seq(1900, 1990, 10))+ # y轴刻度线位置  theme_classic(base_size = 8) + # 设置基本字号为8pt  theme(    axis.line = element_blank(), # 删除原始轴线    panel.border = element_rect(size = 0.5,fill = 'transparent'), # 添加全框线    panel.grid.major = element_line(size = 0.2, linetype = 'solid', color = "gray"), # 开启y轴主网格线    axis.ticks = element_line(size = 0.5), #设置刻度线粗细    axis.ticks.length = unit(1.5, "mm"), # 设置刻度线的长度    legend.position = 'none',    axis.text = element_text(size = 10), # 设置坐标轴标签字号和颜色    axis.title = element_text(size = 10), # 设置坐标轴标题字号    legend.text = element_text(size = 10), # 设置图例文本字号  )​# 图片导出ggsave("正负柱状图.jpeg",  width = 12, height = 10, units = "cm", dpi = 600)

以上。

相关推荐
夜夜敲码19 分钟前
C语言教程(十六): C 语言字符串详解
c语言·开发语言
宋康25 分钟前
C语言结构体和union内存对齐
c语言·开发语言
居然是阿宋35 分钟前
Kotlin高阶函数 vs Lambda表达式:关键区别与协作关系
android·开发语言·kotlin
Cao1234567893211 小时前
简易学生成绩管理系统(C语言)
c语言·开发语言
The Future is mine1 小时前
C# new Bitmap(32043, 32043, PixelFormat.Format32bppArgb)报错:参数无效,如何将图像分块化处理?
开发语言·c#
亿坊电商1 小时前
PHP框架在微服务迁移中能发挥什么作用?
开发语言·微服务·php
烁3471 小时前
每日一题(小白)模拟娱乐篇33
java·开发语言·算法
坐吃山猪2 小时前
Python-Agent调用多个Server-FastAPI版本
开发语言·python·fastapi
88号技师2 小时前
【1区SCI】Fusion entropy融合熵,多尺度,复合多尺度、时移多尺度、层次 + 故障识别、诊断-matlab代码
开发语言·机器学习·matlab·时序分析·故障诊断·信息熵·特征提取
北漂老男孩2 小时前
Java对象转换的多种实现方式
java·开发语言