2011-12-28 8 views
0

私は時間からなる因子変数を持っています。私はそれを因子に変えようとするとき、Rはそれらを最低から最高の順に並べます。 Unforunately、これは私が次のようなもので終わることを意味します時間によるベクトルの並べ替え

1:48:55 1:53:11 1:58:18 10:04:01 10:12:45 10:14:16 
10:20:24 10:21:59 10:23:11 10:23:40 10:30:40 10:34:13 
10:39:47 10:54:33 10:58:43 3:21:59 3:27:38 3:37:58 
3:49:00 4:20:42 4:30:52 4:37:39 4:40:08 4:40:55 
4:42:25 5:03:25 5:10:30 5:10:49 5:12:39 5:14:20 

ので、代わりの順序で時刻を印刷するには、10:00と時間は午前7時前に来ます。

時間を実際の時間ですぐに注文する方法はありますか?

time = c("1:48:55", "1:53:11", "1:58:18", "10:04:01", "10:12:45", "10:14:16", "10:20:24", "10:21:59", "10:23:11", "10:23:40", "10:30:40", "10:34:13", "10:39:47", "10:54:33", "10:58:43", "3:21:59", "3:27:38", "3:37:58", "3:49:00", "4:20:42", "4:30:52", "4:37:39", "4:40:08", "4:40:55", "4:42:25", "5:03:25", "5:10:30", "5:10:49", "5:12:39", "5:14:20") 

time = factor(time) 

答えて

3

この試してみてください:あなたはソートされたベクトルが要因のままにしたい場合は

library(chron) 
sort(times(time)) 

またはこれを:

time[order(times(time))] 
2

項目は、彼らがしている順序になっているので、あなたは彼らがそのために滞在しますが、あなたは回帰は、「適切に」それらを報告しましょうような方法でレベルを設定することができfactorを使用しています。予想通りgtoolsでmixedsort機能は、文字ベクトルをソートします:

require(gtools) 
mixedsort(time) 
[1] "1:48:55" "1:53:11" "1:58:18" "3:21:59" "3:27:38" "3:37:58" "3:49:00" "4:20:42" "4:30:52" 
[10] "4:37:39" "4:40:08" "4:40:55" "4:42:25" "5:03:25" "5:10:30" "5:10:49" "5:12:39" "5:14:20" 
[19] "10:04:01" "10:12:45" "10:14:16" "10:20:24" "10:21:59" "10:23:11" "10:23:40" "10:30:40" "10:34:13" 
[28] "10:39:47" "10:54:33" "10:58:43" 

> time=factor(time, levels= mixedsort(time)) 
> levels(time) 
[1] "1:48:55" "1:53:11" "1:58:18" "3:21:59" "3:27:38" "3:37:58" "3:49:00" "4:20:42" "4:30:52" 
[10] "4:37:39" "4:40:08" "4:40:55" "4:42:25" "5:03:25" "5:10:30" "5:10:49" "5:12:39" "5:14:20" 
[19] "10:04:01" "10:12:45" "10:14:16" "10:20:24" "10:21:59" "10:23:11" "10:23:40" "10:30:40" "10:34:13" 
[28] "10:39:47" "10:54:33" "10:58:43" 
> time 
[1] 1:48:55 1:53:11 1:58:18 10:04:01 10:12:45 10:14:16 10:20:24 10:21:59 10:23:11 10:23:40 10:30:40 
[12] 10:34:13 10:39:47 10:54:33 10:58:43 3:21:59 3:27:38 3:37:58 3:49:00 4:20:42 4:30:52 4:37:39 
[23] 4:40:08 4:40:55 4:42:25 5:03:25 5:10:30 5:10:49 5:12:39 5:14:20 
30 Levels: 1:48:55 1:53:11 1:58:18 3:21:59 3:27:38 3:37:58 3:49:00 4:20:42 4:30:52 4:37:39 ... 10:58:43 

あなたは彼らがあなたと動作するように時間のクラスを選択する必要があります時間値としてソートを取得したい場合。クロンパッケージには、一つの可能​​な選択肢である:

time = c("1:48:55", "1:53:11", "1:58:18", "10:04:01", "10:12:45", "10:14:16", "10:20:24", "10:21:59", "10:23:11", "10:23:40", "10:30:40", "10:34:13", "10:39:47", "10:54:33", "10:58:43", "3:21:59", "3:27:38", "3:37:58", "3:49:00", "4:20:42", "4:30:52", "4:37:39", "4:40:08", "4:40:55", "4:42:25", "5:03:25", "5:10:30", "5:10:49", "5:12:39", "5:14:20") 

> chron(times=time) 
[1] 01:48:55 01:53:11 01:58:18 10:04:01 10:12:45 10:14:16 10:20:24 10:21:59 10:23:11 10:23:40 10:30:40 
[12] 10:34:13 10:39:47 10:54:33 10:58:43 03:21:59 03:27:38 03:37:58 03:49:00 04:20:42 04:30:52 04:37:39 
[23] 04:40:08 04:40:55 04:42:25 05:03:25 05:10:30 05:10:49 05:12:39 05:14:20 
> sort(chron(times=time)) 
[1] 01:48:55 01:53:11 01:58:18 03:21:59 03:27:38 03:37:58 03:49:00 04:20:42 04:30:52 04:37:39 04:40:08 
[12] 04:40:55 04:42:25 05:03:25 05:10:30 05:10:49 05:12:39 05:14:20 10:04:01 10:12:45 10:14:16 10:20:24 
[23] 10:21:59 10:23:11 10:23:40 10:30:40 10:34:13 10:39:47 10:54:33 10:58:43 
+0

をショートに加え:その要因に注意してください。定義によって順序付けられていない!しかし、Rには必要なものがすべて含まれているので、 'ordered'というデータ型があります。これは定義された順序を持つ単なる要素です。 DWinsの答えで 'factor'を' ordered'に置き換えると、あなたのデータ型はもっと意味があります(ただし、因子だけを表示すると、目立った違いはありませんが、いくつかの統計的方法ではそうなります)。 – Thilo

+1

注文された要因の私の経験は彼らがどこへ行っても混乱を招くので、初心者には勧めません。 –

関連する問題