我使用下面的繪製如下圖:僅顯示正在使用的標籤?
data <- structure(list(Type1 = c("DB", "DB", "DB", "DB", "DB", "DB",
"DB", "DB", "DB", "DB", "DB", "DB", "DB", "Manual", "Manual",
"Manual", "Manual", "Manual", "Manual", "Manual", "Manual", "Manual",
"Manual", "Manual", "Manual", "Manual", "Manual", "Manual"),
Type2 = c(1L, 1L, 1L, 1L, 1L, 2L, 2L, 2L, 2L, 3L, 3L, 3L,
3L, 1L, 1L, 1L, 1L, 1L, 2L, 2L, 2L, 2L, 2L, 3L, 3L, 3L, 3L,
3L), Category = c("A", "B", "C", "D", "E", "A", "B", "F",
"G", "A", "B", "C", "H", "I", "J", "K", "L", "M", "O", "J",
"P", "K", "Q", "M", "K", "P", "J", "P"), Percent = c("83.5106383",
"9.574468085", "5.85106383", "0.531914894", "1/188*100",
"85.24590164", "11.47540984", "1/61*100", "1.639344262",
"90", "3.333333333", "3.333333333", "3.333333333", "20.10582011",
"10.05291005", "6.349206349", "5.82010582", "4.761904762",
"31.14754098", "16.39344262", "6.557377049", "6.557377049",
"4.918032787", "30", "23.33333333", "16.66666667", "10",
"6.666666667")), .Names = c("Type1", "Type2", "Category",
"Percent"), row.names = c(NA, -28L), class = "data.frame")
data$Percent <- as.numeric(data$Percent)
g= ggplot(data, aes(x=Category, y=Percent)) +
geom_bar(width=0.8, stat="identity", position=position_dodge()) +
facet_grid(Type1 ~ Type2,) +
theme_bw() +
coord_flip() +
scale_y_continuous(limits=c(0,100))
print(g)
有什麼辦法,我可以積等taht每行僅使用標籤是非零?例如,採取DB
行。它只使用6個標籤,但顯示所有16個標籤,因爲其他10個正被Manual
部分數據使用。對於Manual
行也是如此。我正在尋找的是這樣的:
1 2 3
H
G
D DB
C
B
A
Q
P
O
G MANUAL
M
L
K
J
I
有關如何做到這一點的任何建議?
我這個玩周圍的位(後我固定在你的榜樣數據的問題),我開始認爲facet_grid和scales參數可能存在一些問題。但是,您也可以使用facet_wrap,而且似乎可行。 – joran 2012-04-10 03:32:22
@joran:+1謝謝你的時間。我也玩過,我可以確認有一個錯誤。我會盡快報告。 – Legend 2012-04-12 19:46:14