これは他の質問(?)と同じですが、同じ解決策が考えられます。
library(xts)
set.seed(42)
x <- xts(rnorm(1000000), as.POSIXct('2012-10-07') - (1000000:1) )
index(x) = index(x) - (9*3600)
x1 <- lapply ( split(x,'days'), function(one_day){ index(one_day) = index(one_day) + 9*3600; one_day } )
index(x) = index(x) + (9*3600)
これがxです:
2012-09-25 10:13:20 1.3709584
2012-09-25 10:13:21 -0.5646982
2012-09-25 10:13:22 0.3631284
...
2012-10-06 23:59:57 0.7505021
2012-10-06 23:59:58 -0.4726833
2012-10-06 23:59:59 1.1356617
x1[ 1 ]は次のとおりです。
2012-09-25 10:13:20 1.3709584
2012-09-25 10:13:21 -0.5646982
2012-09-25 10:13:22 0.3631284
...
2012-09-26 08:59:57 -0.7079315
2012-09-26 08:59:58 -0.2135840
2012-09-26 08:59:59 -1.8307128
x1 [[2]]:
2012-09-26 09:00:00 2.3205603
2012-09-26 09:00:01 1.8911404
2012-09-26 09:00:02 -0.8547244
...
2012-09-27 08:59:57 -0.5731661
2012-09-27 08:59:58 -1.5224021
2012-09-27 08:59:59 -0.5316183
そしてx1[[12]]:
2012-10-06 09:00:03 0.9222899
2012-10-06 09:00:04 -0.2010127
2012-10-06 09:00:05 -1.8403161
...
2012-10-06 23:59:54 -0.5931701
2012-10-06 23:59:55 -1.1656284
2012-10-06 23:59:56 0.7000441
別のアプローチが必要な場合は、タイムゾーンを変更することもできます。
Sys.setenv(TZ = "UTC")
library(xts)
set.seed(42)
x <- xts(rnorm(1000000), as.POSIXct('2012-10-07') - (1000000:1) )
indexTZ(x) = 'UTC+9'
x1 <- lapply ( split(x,'days'), function(one_day){ indexTZ(one_day) = 'UTC'; one_day } )
午前9時の休憩が実際に夏の午前8時である場合は、タイムゾーンアプローチを使用する必要があります。これは、Rが夏の調整を自動的に行うためです。そうでない場合は、前のアプローチを使用します。次に、私が意味することを正確に説明し、タイムゾーンデータベースのバグに対して脆弱ではありません。(TZデータベースはWindowsでも異なる動作をする可能性があると思います...私はまだそれをテストする機会がありませんでした。)