xls
を使用してファイルをインポートしていますgdata
。日付の変換に使用して日付列をas.Date
変換しています
のマニュアルによるas.Date
と、日付の原点はプラットフォームに依存するため、それに応じてどの原点を使用するかを決定しています
.origin <- ifelse(Sys.info()[['sysname']] == "Windows", "1899-12-30", "1904-01-01")
as.Date(myData$Date, origin=.origin)
ただし、ファイルが読み取られているプラットフォームまたはファイルが書き込まれたプラットフォームを検討する必要があるかどうか疑問に思っています。
価値があるのは、私は現在、Excel のない Linux ボックスでコードをテストしており、正しい日付は次を使用して生成されますorigin="1904-01-01"
`?as.Date' の引用
## date given as number of days since 1900-01-01 (a date in 1989)
as.Date(32768, origin = "1900-01-01")
## Excel is said to use 1900-01-01 as day 1 (Windows default) or
## 1904-01-01 as day 0 (Mac default), but this is complicated by Excel
## treating 1900 as a leap year.
## So for dates (post-1901) from Windows Excel
as.Date(35981, origin = "1899-12-30") # 1998-07-05
## and Mac Excel
as.Date(34519, origin = "1904-01-01") # 1998-07-05
## (these values come from http://support.microsoft.com/kb/214330)