我有一个 data.frame xy
,我在下面的代码中绘制它。
有没有一种方法可以将xy plot() 中的xx
and转换为命令,以便我可以在段命令之后设置和添加以便更好地控制它?yy
points()
type='n'
points()
xy <- data.frame(NAME=c("NAME1","NAME1","NAME1","NAME2","NAME2","NAME2"),ID=c(87,87,87,199,199,199), X_START_YEAR=c(1984,1986,1984,1899,1909,1924),Y_START_VALUE=c(75,25,-90,-8,-55,-10),X_END_YEAR=c(1986,1994,1999,1909,1924,1927), Y_END_VALUE=c(20,50,-15,-70,-80,-100))
xy
NAME ID X_START_YEAR Y_START_VALUE X_END_YEAR Y_END_VALUE
1 NAME1 87 1984 75 1986 20
2 NAME1 87 1986 25 1994 50
3 NAME1 87 1984 -90 1999 -15
4 NAME2 199 1899 -8 1909 -70
5 NAME2 199 1909 -55 1924 -80
6 NAME2 199 1924 -10 1927 -100
ind <- split(xy,xy$ID)
for (x in ind){
xx = unlist(x[,grep('X_',colnames(x))])
yy = unlist(x[,grep('Y_',colnames(x))])
fname <- paste0(x[1, 'ID'], '.png')
png(fname, width=1679, height=1165, res=150)
par(mar=c(6,8,6,5))
plot(xx,
yy,
main=unique(x[,1]),
xlab="Time [Years]",
ylab="Value [m]")
axis(1, at = seq(1000, 2050, 5), cex.axis=1, labels=FALSE, tcl=-0.3)
axis(2, at = seq(-100000, 100000, 500), cex.axis=1, labels=FALSE, tcl=-0.3)
x <- x[,-1]
segments(x[,2],x[,3],x[,4],x[,5],lwd=2)
dev.off()
}
如果可能的话,如果 x 轴可以处于固定范围(例如从 1940 年到 2014 年)并且如果存在 1940 年之前的值,那么 x 轴应该是自动的。y 轴的范围总是不同的。我怎么能把它合并到我的代码中?