[2] | 1 | ;------------------------------------------------------------ |
---|
| 2 | ;------------------------------------------------------------ |
---|
| 3 | ;------------------------------------------------------------ |
---|
| 4 | ;+ |
---|
| 5 | ; NAME: juldate |
---|
| 6 | ; |
---|
| 7 | ; PURPOSE: gives julian date equivalent of a date in vairmer |
---|
| 8 | ; ( yymmdd or yyyymmdd ) format |
---|
| 9 | ; sets month, day and year to the corresp values |
---|
| 10 | ; |
---|
| 11 | ; CATEGORY: bidouilles dates |
---|
| 12 | ; |
---|
| 13 | ; CALLING SEQUENCE: date = juldate(930124) |
---|
| 14 | ; |
---|
| 15 | ; INPUTS:date de la forme yymmdd ou yyyymmdd |
---|
| 16 | ; |
---|
| 17 | ; KEYWORD PARAMETERS: |
---|
| 18 | ; |
---|
| 19 | ; VRAIDATE: pour ne pasa transformer l''annnee 01 en 1901 |
---|
| 20 | ; |
---|
| 21 | ; OUTPUTS:date en jour julien |
---|
| 22 | ; |
---|
| 23 | ; COMONTHON BLOCKS: |
---|
| 24 | ; common.pro vraidate |
---|
| 25 | ; |
---|
| 26 | ; SIDE EFFECTS: |
---|
| 27 | ; l'annee 0 n'existant pas, qd year est nulle on calcule le |
---|
| 28 | ; jour julien de l'annee -1. |
---|
| 29 | ; COMPATIBLE AVEC L'AN 2000 !!!: une date de la forme yymmdd est |
---|
| 30 | ; donvertit sous la forme yyyymmdd a l''aide de vraidate. |
---|
| 31 | ; Attention, les variables globales year, month day sont attribuees |
---|
| 32 | ; |
---|
| 33 | ; MODIFICATION HISTORY: Jerome Vialard (jv@lodyc.jussieu.fr) |
---|
| 34 | ; 2/7/98 |
---|
| 35 | ;- |
---|
| 36 | ;------------------------------------------------------------ |
---|
| 37 | ;------------------------------------------------------------ |
---|
| 38 | ;------------------------------------------------------------ |
---|
| 39 | function juldate, vvdate, _EXTRA = ex |
---|
| 40 | vdate = vvdate |
---|
| 41 | vdate = vraidate(vdate, _EXTRA = ex) |
---|
| 42 | @common |
---|
| 43 | ;------------------------------------------------------------ |
---|
| 44 | year=vdate/10000 |
---|
| 45 | month=vdate/100 - year*100 |
---|
| 46 | day=abs(vdate - year*10000 - month*100) |
---|
| 47 | month = abs(month) |
---|
| 48 | ; |
---|
| 49 | mm = month & dd = day & yy = year |
---|
| 50 | ;------------------------------------------------------------ |
---|
| 51 | ndate = n_elements(vdate) |
---|
| 52 | if total(mm EQ 0) EQ ndate then mm[*] = 6 |
---|
| 53 | if total(dd EQ 0) EQ ndate then dd[*] = 15 |
---|
| 54 | if total(yy EQ 0) EQ ndate THEN yy[*] = -1 |
---|
| 55 | ;------------------------------------------------------------ |
---|
| 56 | return, julday(mm,dd,yy, _EXTRA = ex) |
---|
| 57 | ;------------------------------------------------------------ |
---|
| 58 | return, -1 |
---|
| 59 | end |
---|
| 60 | ;------------------------------------------------------------ |
---|
| 61 | |
---|