2014-11-13 7 views
11

Ho qualche codice di esempio che contiene un ciclo for e crea alcuni appezzamenti come questo (il mio dati effettivi crea diverse migliaia di trame):R: Il testo barra di avanzamento nel ciclo for

xy <- structure(list(NAME = structure(c(2L, 3L, 1L, 1L), .Label = c("CISCO","JOHN", "STEPH"), class = "factor"), ID = c(41L, 49L, 87L, 87L), X_START_YEAR = c(1965L, 1948L, 1959L, 2003L), Y_START_VALUE = c(940L,-1760L, 110L, 866L), X_END_YEAR = c(2005L, 2000L, 2000L, 2007L), Y_END_VALUE = c(940L, -1760L, 110L, 866L), LC = structure(c(1L,1L, 2L, 2L), .Label = c("CA", "US"), class = "factor")), .Names = c("NAME", "ID", "X_START_YEAR", "Y_START_VALUE", "X_END_YEAR", "Y_END_VALUE","LC"), class = "data.frame", row.names = c(NA, -4L)) 

ind <- split(xy,xy$ID) # split by ID for different plots 

# Plots 
for (i in ind){ 
    xx = unlist(i[,grep('X_',colnames(i))]) 
    yy = unlist(i[,grep('Y_',colnames(i))])  
    fname <- paste0(i[1, 'ID'],'.png') 
    png(fname, width=1679, height=1165, res=150) 
    par(mar=c(6,8,6,5)) 
    plot(xx,yy,type='n',main=unique(i[,1]), xlab="Time [Years]", ylab="Value [mm]") 
    i <- i[,-1] 
    segments(i[,2],i[,3],i[,4],i[,5],lwd=2) 
    points(xx, yy, pch=21, bg='white', cex=0.8) 
    dev.off() 
} 

per vedere i progressi di il ciclo for sarei interessato a incorporare una barra di avanzamento sul mio codice. Come ho trovato dalla documentazione R, c'è il txtProgressBarhttp://stat.ethz.ch/R-manual/R-patched/library/utils/html/txtProgressBar.html Dall'esempio di quella pagina capisco che devi scrivere il ciclo for in una funzione per chiamarla in seguito, che sto combattendo con il mio esempio.

Come è possibile implementare una barra di avanzamento nel ciclo for?

risposta

12

per la barra di avanzamento per lavorare è necessario un numero per tenere traccia dei progressi. questo è uno dei motivi, come regola generale, preferisco usare con (i in 1:length(ind)) invece di mettere direttamente l'oggetto che voglio lì. In alternativa, creerai un'altra variabile stepi che esegui stepi = stepi + 1 in ogni iterazione.

bisogna prima creare l'oggetto progressbar all'esterno del ciclo

pb = txtProgressBar(min = 0, max = length(ind), initial = 0) 

poi dentro è necessario aggiornare con ogni iterazione

setTxtProgressBar(pb,stepi) 

o

setTxtProgressBar(pb,i) 

Questo funziona male se il ciclo contiene anche i comandi print

+0

controllare anche le opzioni di txtProgressBar. Sembra molto meglio se li usi – OganM

+0

sì, l'ho fatto, grazie. L'unica cosa che sembra non funzionare sono le opzioni di titolo e di etichetta? Ti capita di saperlo perché sarebbe bello avere un titolo. – kurdtc

+1

Ho trovato una soluzione utilizzando la funzione 'cat()'. – kurdtc

5

si potrebbe scrivere molto semplice al volo per mostrare per cento completato:

n <- 100 
for (ii in 1:n) { 
    cat(paste0(round(ii/n * 100), '% completed')) 
    Sys.sleep(.05) 
    if (ii == n) cat(': Done') 
    else cat('\014') 
} 
# 50% completed 

O uno di replicare la barra di testo:

n <- 100 
for (ii in 1:n) { 
    width <- options()$width 
    cat(paste0(rep('=', ii/n * width), collapse = '')) 
    Sys.sleep(.05) 
    if (ii == n) cat('\014Done') 
    else cat('\014') 
} 
# ============================