データフレームを取得し、ggplot2を使用してそのデータフレームからいくつかの列をプロットする関数があります。ggplot2のaes()関数はlabel引数を取り、sprintfを使用してその引数をフォーマットしたいと思います。これは、他のコードでこれまで何度も行ったことです。フォーマット文字列をsprintf(この場合は「%1.1f」)に渡すと、「オブジェクトが見つかりません」と表示されます。round()関数を使用してその関数に引数を渡すと、問題なくそれを見つけることができます。format()についても同じことが言えます。どうやらsprintf()だけがオブジェクトを見ることができません。
最初は、これはコードをインラインで使用するのではなく関数を呼び出すことによって引き起こされる遅延評価の問題だと思いましたが、sprintfに渡すフォーマット文字列にforce()を使用しても問題は解決しません。私はこれを回避することができますが、なぜそれが起こるのか知りたいです。もちろん、私が見落としていたのは些細なことかもしれません。
Q. sprintf()が文字列オブジェクトを見つけられないのはなぜですか?
コードは次のとおりです(より最小限の例のために編集および整理されています)
require(gdata)
require(ggplot2)
require(scales)
require(gridExtra)
require(lubridate)
require(plyr)
require(reshape)
set.seed(12345)
# Create dummy time series data with year and month
monthsback <- 64
startdate <- as.Date(paste(year(now()),month(now()),"1",sep = "-")) - months(monthsback)
mydf <- data.frame(mydate = seq(as.Date(startdate), by = "month", length.out = monthsback), myvalue5 = runif(monthsback, min = 200, max = 300))
mydf$year <- as.numeric(format(as.Date(mydf$mydate), format="%Y"))
mydf$month <- as.numeric(format(as.Date(mydf$mydate), format="%m"))
getchart_highlight_value <- function(
plotdf,
digits_used = 1
)
{
force(digits_used)
#p <- ggplot(data = plotdf, aes(x = month(mydate, label = TRUE), y = year(mydate), fill = myvalue5, label = round(myvalue5, digits_used))) +
# note that the line below using sprintf() does not work, whereas the line above using round() is fine
p <- ggplot(data = plotdf, aes(x = month(mydate, label = TRUE), y = year(mydate), fill = myvalue5, label = sprintf(paste("%1.",digits_used,"f", sep = ""), myvalue5))) +
scale_x_date(labels = date_format("%Y"), breaks = date_breaks("years")) +
scale_y_reverse(breaks = 2007:2012, labels = 2007:2012, expand = c(0,0)) +
geom_tile() + geom_text(size = 4, colour = "black") +
scale_fill_gradient2(low = "blue", high = "red", limits = c(min(plotdf$myvalue5), max(plotdf$myvalue5)), midpoint = median(plotdf$myvalue5)) +
scale_x_discrete(expand = c(0,0)) +
opts(panel.grid.major = theme_blank()) +
opts(panel.background = theme_rect(fill = "transparent", colour = NA)) +
png(filename = "c:/sprintf_test.png", width = 700, height = 300, units = "px", res = NA)
print(p)
dev.off()
}
getchart_highlight_value (plotdf <- mydf,
digits_used <- 1)