I have a set of data and I want to plot a bar plot for the data. The example of data is shown below:
yq flag n ratio
<yearqtr> <fct> <int> <dbl>
1 2011 Q1 0 269 0.610
2 2011 Q1 1 172 0.390
3 2011 Q2 0 266 0.687
4 2011 Q2 1 121 0.313
5 2011 Q3 0 239 0.646
6 2011 Q3 1 131 0.354
7 2011 Q4 0 153 0.668
8 2011 Q4 1 76 0.332
9 2012 Q1 0 260 0.665
10 2012 Q1 1 131 0.335
11 2012 Q2 0 284 0.676
12 2012 Q2 1 136 0.324
13 2012 Q3 0 197 0.699
14 2012 Q3 1 85 0.301
15 2012 Q4 0 130 0.688
16 2012 Q4 1 59 0.312
17 2013 Q1 0 273 0.705
18 2013 Q1 1 114 0.295
19 2013 Q2 0 333 0.729
20 2013 Q2 1 124 0.271
What I want to do is basically plotting the ratio for each flag in each quarter. I wrote the code below:
data$flag <- as.factor(data$flag)
ggplot(data=data, aes(x=yq, y=ratio, fill=flag)) +
geom_bar(stat="identity", color="black", position=position_dodge())+
theme_minimal() +
scale_fill_manual(values=c('#999999','#E69F00'))
The result is shown below:

But what I actually want is to show all quarters on the x-axis and maybe in vertical form for better visualization. I tried using scale_x_discrete(limits=yq) however, this is not the correct answer and return an error. How can I do this?
It looks like your yq column is in year-quarter format (as defined in the zoo package). For ggplot, it might be best to convert this to date format and specify the breaks like this:
library(ggplot2)
library(zoo)
data$flag <- as.factor(data$flag)
ggplot(data=data, aes(as.Date(yq), ratio, fill = flag)) +
geom_col(color="black", position = position_dodge()) +
scale_x_date(date_breaks = "3 months", guide = guide_axis(n.dodge = 2)) +
labs(x = "Year / Quarter") +
scale_fill_manual(values=c('#999999','#E69F00')) +
theme_minimal()

Or you could stack the columns:
ggplot(data=data, aes(as.Date(yq), ratio, fill = flag)) +
geom_col(color="black", position = position_stack()) +
scale_x_date(date_breaks = "3 months", guide = guide_axis(n.dodge = 2)) +
labs(x = "Year / Quarter") +
scale_fill_manual(values=c('#999999','#E69F00')) +
theme_minimal()

Data
data <- structure(list(yq = structure(c(2011, 2011, 2011.25, 2011.25,
2011.5, 2011.5, 2011.75, 2011.75, 2012, 2012, 2012.25, 2012.25,
2012.5, 2012.5, 2012.75, 2012.75, 2013, 2013, 2013.25, 2013.25
), class = "yearqtr"), flag = c(0L, 1L, 0L, 1L, 0L, 1L, 0L, 1L,
0L, 1L, 0L, 1L, 0L, 1L, 0L, 1L, 0L, 1L, 0L, 1L), n = c(269L,
172L, 266L, 121L, 239L, 131L, 153L, 76L, 260L, 131L, 284L, 136L,
197L, 85L, 130L, 59L, 273L, 114L, 333L, 124L), ratio = c(0.61,
0.39, 0.687, 0.313, 0.646, 0.354, 0.668, 0.332, 0.665, 0.335,
0.676, 0.324, 0.699, 0.301, 0.688, 0.312, 0.705, 0.295, 0.729,
0.271)), row.names = c(NA, -20L), class = c("tbl_df", "tbl",
"data.frame"))
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With