Ecco il mio approccio di subroutine a questo problema. trasforma un intero nell'intervallo 0: 9999 come carattere. Ad esempio, INTEGER 123 viene trasformato nel carattere 0123. spero che sia d'aiuto.
P.S. - scusa per i commenti; hanno un senso in rumeno: P
subroutine nume_fisier (i,filename_tot)
implicit none
integer :: i
integer :: integer_zeci,rest_zeci,integer_sute,rest_sute,integer_mii,rest_mii
character(1) :: filename1,filename2,filename3,filename4
character(4) :: filename_tot
! Subrutina ce transforma un INTEGER de la 0 la 9999 in o serie de CARACTERE cu acelasi numar
! pentru a fi folosite in numerotarea si denumirea fisierelor de rezultate.
if(i<=9) then
filename1=char(48+0)
filename2=char(48+0)
filename3=char(48+0)
filename4=char(48+i)
elseif(i>=10.and.i<=99) then
integer_zeci=int(i/10)
rest_zeci=mod(i,10)
filename1=char(48+0)
filename2=char(48+0)
filename3=char(48+integer_zeci)
filename4=char(48+rest_zeci)
elseif(i>=100.and.i<=999) then
integer_sute=int(i/100)
rest_sute=mod(i,100)
integer_zeci=int(rest_sute/10)
rest_zeci=mod(rest_sute,10)
filename1=char(48+0)
filename2=char(48+integer_sute)
filename3=char(48+integer_zeci)
filename4=char(48+rest_zeci)
elseif(i>=1000.and.i<=9999) then
integer_mii=int(i/1000)
rest_mii=mod(i,1000)
integer_sute=int(rest_mii/100)
rest_sute=mod(rest_mii,100)
integer_zeci=int(rest_sute/10)
rest_zeci=mod(rest_sute,10)
filename1=char(48+integer_mii)
filename2=char(48+integer_sute)
filename3=char(48+integer_zeci)
filename4=char(48+rest_zeci)
endif
filename_tot=''//filename1//''//filename2//''//filename3//''//filename4//''
return
end subroutine nume_fisier
Due commenti: - non c'è bisogno di discriminare sul valore di I; il formato (I0) restituirà un intero senza spazio; inoltre, se vuoi una larghezza fissa e padding con zero (come "output001.txt"), devi usare (I0.3) - il formato (A5I2) non è valido per Fortran secondo alcuna norma, poiché gli specificatori di formato sono da separare da una virgola: (A5, I2) –
Bene, era per scopi didattici, non inteso come soluzione. In generale io uso gli zeri padding (come ordina gentilmente), ma i thingie I0 di cui non ero a conoscenza. Grazie!! (corretto le virgole, penso che il mio stile fosse quello vecchio, ancora accettato) –
@ F'x grazie per il commento, davvero utile. Infatti anche il trim non funzionerà se il numero k di cifre non è uguale a "(Ik)" nel formato, quindi basta usare "(I0)" in modo che non sia necessario adattare il formato. – gluuke