2016-07-30 7 views
1

私のウェブサイトの特定のウェブページへの時間別の訪問をプロットしたい。 x軸は時間(0〜23)を示し、y軸は一意の訪問数を示します。最高値のY軸ラベルが印刷されない

私はplot()に軸を押して、それにaxis()を追加しています。

(省略記号は、コードサンプルの列をrepresend私はコードの構造のより良い視覚的に明確にするためにこれを左に。。)

axis(2, 
    at = seq(min(...), max(...), 1), 
    labels = c(min(...), 
       rep.int("", max(...) - min(...) - 1), 
       max(...) 
       ) 
    ) 

しかし:私は最低と最高のyの値がラベルたいですプロットに、最高値でラベルが表示されない:たまに

image of plot with missing label

を(値の範囲に応じて)私はBを表示する最高値のラベルを取得することができますyをrep.int("" ...からrep.int(" "に変更します。つまり、ダンプにスペースを付けてラベル付けしますが、これは常に機能しません。

なぜRが最も高いラベルを印刷しないのですか?さらに重要なのは、

Rに最高のラベルを印刷させるにはどうすればいいですか?


完全なコード例:

sitzungen <- c(0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 2, 0, 8, 4, 0, 8, 3, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 1, 1, 2, 0, 0, 2, 0, 0, 2, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 2, 0, 0, 0, 0, 2, 0, 2, 2, 1, 0, 0, 0, 1, 0, 0, 1, 3, 0, 0, 0, 0, 1, 1, 1, 1, 0, 1, 0, 0, 4, 1, 2, 1, 7, 7, 1, 0, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 1, 0, 1, 1, 1, 1, 2, 2, 2, 2, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 1, 1, 3, 8, 4, 1, 2, 0, 1, 1, 0, 0, 5, 0, 3, 3, 2, 3, 1, 2, 0, 1, 2, 0, 0, 0, 1, 0, 1, 2, 3, 0, 0, 3, 1, 6, 3, 9, 1, 0, 2, 1, 4, 8, 2, 2, 2, 0, 0, 0, 2, 1, 3, 1, 1, 2, 1, 2, 3, 1, 4, 3, 0, 2, 3, 1, 3, 1, 5, 2, 0, 0, 1, 0, 1, 2, 1, 0, 3, 0, 1, 0, 3, 7, 2, 2, 1, 2, 2, 2, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 2, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 12, 15, 2, 2, 1, 0, 0, 0, 0, 0, 2, 3, 0, 3, 0, 2, 1, 1, 2, 2, 4, 2, 1, 4, 2, 1, 2, 2, 1, 0, 0, 0, 7, 0, 2, 4, 2, 0, 2, 3, 5, 2, 1, 4, 4, 2, 0, 2, 4, 0, 0, 0, 0, 0, 0, 0, 1, 3, 0, 2, 1, 2, 1, 1, 2, 1, 4, 1, 1, 1, 0, 0, 3, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0) 
stunde <- rep(0:23, 20) 
stuendlich <- data.frame(cbind(stunde, sitzungen)) 
aggr <- aggregate(sitzungen ~ stunde, stuendlich, sum) 
aggr <- rbind(aggr, c(24, aggr[which(aggr$stunde == "23"),]$sitzungen)) 
plot(aggr, type = "s", xlim = c(0, 24), axes = FALSE, xlab = "Stunde", ylab = "Sitzungen", main = "Sitzungen pro Stunde (kumuliert)") 
axis(1, at = seq(0.5, 23.5, 1), labels = 0:23) 
axis(2, at = seq(min(aggr$sitzungen), max(aggr$sitzungen), 1), labels = c(min(aggr$sitzungen), rep.int(" ", max(aggr$sitzungen) - min(aggr$sitzungen) - 1), max(aggr$sitzungen))) 

答えて

0

" "または""を使用しないでください。 NA使用:

axis(2, at = seq(min(aggr$sitzungen), max(aggr$sitzungen), 1), 
    labels = c(min(aggr$sitzungen), 
       rep.int(NA, max(aggr$sitzungen) - min(aggr$sitzungen) - 1), 
       max(aggr$sitzungen))) 

enter image description here

+1

ブリリアント!ありがとうございました :-) –

関連する問題