[R] Strange behaviour of as.Date function
Gabor Grothendieck
ggrothendieck at gmail.com
Fri Sep 23 15:16:19 CEST 2005
When it converts the time to Date it does it relative to the
GMT time zone, not your time zone. When its July 1st
in your time zone it can be June 30th in the GMT time zone.
See the article in R News 4/1 Help Desk, and the table at the
end of the article in particular, on ways to handle this.
On 9/23/05, Vittorio <vdemart1 at tin.it> wrote:
> Dear All,
> I'm happily extracting data of temperature from an oracle db
> under R via RODBC. After manipulating the extracted data I put them
> into a data.frame 'dati' which is as follows:
>
> > dati
> DATA tm.
> UDINE/RIVOLTO tm.TORINO/CASELLE
> 1 2005-07-01
> 22.35 23.80
> 2 2005-07-02 22.70
> 22.85
> 3 2005-07-03 23.80 24.30
> 4 2005-07-
> 04 23.80 25.40
> ..........
>
> and
>
> > str(dati)
> `data.frame': 11 obs. of 3 variables:
> $ DATA :'POSIXct',
> format: chr "2005-07-01" "2005-07-02" "2005-07-03" "2005-07-04" ...
> $
> tm.UDINE/RIVOLTO : num 22.4 22.7 23.8 23.8 21.8 ...
> $ tm.
> TORINO/CASELLE: num 23.8 22.9 24.3 25.4 21.8 ...
> - attr(*,
> "reshapeWide")=List of 5
> ..$ v.names: NULL
> ..$ timevar: chr "NOME"
> ..$ idvar : chr "DATA"
> ..$ times : Factor w/ 2 levels
> "TORINO/CASELLE",..: 2 1
> ..$ varying: chr [1, 1:2] "tm.UDINE/RIVOLTO"
> "tm.TORINO/CASELLE"
> >
>
> You see that the first field DATA is POSIXct
>
> Now
> > dati[1,1]
> [1] "2005-07-01 ora solare Europa occidentale"
>
> BUT
>
> >
> as.Date(dati[1,1],"%d%m%Y")
> [1] "2005-06-30"
>
> How come?
> What is wrong
> with it (or better with me)?
>
> Ciao
> Vittorio
More information about the R-help
mailing list