Some years back, before I learned R, I put together an Excel spreadsheet to make a pocket calendar. The
Hipster PDA was all the rage, but I preferred something smaller, like the
PocketMod, but not so cute.
I recently converted this to R.
# make a 4-page pdf with a 15 week pocket calendar
# print out landscape, double-sided, open to left
# usage:
# 'make15(start="m/d/yyyy")'
# I start on a Monday.
MonthString <- function(d1,d2) {
# d1 and d2 are Date objects
# returns a string of the month(s) and year(s) of d1 and d2
if (format(d1,'%Y%')!=format(d2,'%Y')) return(paste(format(d1,"%b %Y"),format(d2,"%b %Y"),sep=' - '))
if (format(d1,'%b%')!=format(d2,'%b')) return(paste(format(d1,"%b"),format(d2,"%b %Y"),sep=' - '))
return(format(d1,"%b %Y"))
}
make15 <- function(start) {
start <- as.Date(start,format="%m/%d/%Y")
days <- start+0:104
panelorder <- c(1,2,3,4,14,13,16,15,5,6,7,8,10,9,12,11)
filename <- paste("cal-15_",start,".pdf",sep="")
pdf(file=filename,height=8.5,width=11)
par(mfcol=c(2,2),mar=c(.5,.5,.5,.5))
for(i in panelorder) {
plot(1,1,type='n',xlim=c(0,1),ylim=c(0,1),bty='n',axes=FALSE,
xlab='',ylab='')
if(i==16) {
rect(.55,0,1,1)
text(.75,c(.75,.6),format(c(days[1],days[105]),"%B %d, %Y"))}
else {
rect(0,.75,.5,1,col=grey(.95),border=NA)
text(.25,1-.02,MonthString(days[(i-1)*7+1],days[(i-1)*7+7]),adj=c(.5,1))
segments(0,1:3/4,1)
text(0,3:1/4-.02,format(days[(i-1)*7+1:3],"%a %d"),adj=c(0,1))
text(1,4:1/4-.02,format(days[102:105-(i-1)*7],"%a %d"),adj=c(1,1))
}
}
dev.off()
print(paste(filename,'starts on a',format(start,"%A")))
}
The function
make15("7/8/2013")
will make a 15 week calendar starting July 8 on a four page PDF, size 8.5 x 11 inches. Print double sided, cut in quarters, assemble, and staple. I usually carry two, held together by an elastic band.
No comments:
Post a Comment