Сортировка строк в data.table в порядке убывания по строковому ключу 'order (-x, v)' выдает ошибку в data.table 1.9.4 или более ранней версии.

Скажем, у меня есть следующий data.table в R:

  library(data.table)
  DT = data.table(x=rep(c("b","a","c"),each=3), y=c(1,3,6), v=1:9)

Я хочу заказать его по двум столбцам (например, столбцы x и v). Я использовал это:

 DT[order(x,v)] # sorts first by x then by v (both in ascending order)

Но теперь я хочу отсортировать его по x (в порядке убывания) и иметь следующий код:

  DT[order(-x)] #Error in -x : invalid argument to unary operator

Поэтому я считаю, что эта ошибка связана с тем, что class(DT$x)=character. Не могли бы вы дать мне какое-либо предложение, чтобы решить эту проблему?

Я знаю, что могу использовать DT[order(x,decreasing=TRUE)], но я хочу знать синтаксис для сортировки по нескольким столбцам, используя оба способа (некоторые уменьшающиеся, некоторые увеличивающиеся) одновременно.

Обратите внимание, что если вы используете DT[order(-y,v)], результат будет одобрен, но если вы используете DT[order(-x,v)], появляется ошибка. Итак, мой вопрос: как решить эту ошибку?

Ответ 1

Обновить

data.table v1.9. 6+ теперь поддерживает первоначальную попытку OP, и следующий ответ больше не нужен.


Вы можете использовать DT[order(-rank(x), y)].

   x y v
1: c 1 7
2: c 3 8
3: c 6 9
4: b 1 1
5: b 3 2
6: b 6 3
7: a 1 4
8: a 3 5
9: a 6 6

Ответ 2

Вы можете использовать только - для числовых записей, поэтому вы можете использовать уменьшение и отменять те, которые вы хотите в порядке возрастания:

DT[order(x,-v,decreasing=TRUE),]
      x y v
 [1,] c 1 7
 [2,] c 3 8
 [3,] c 6 9
 [4,] b 1 1
 [5,] b 3 2
 [6,] b 6 3
 [7,] a 1 4
 [8,] a 3 5
 [9,] a 6 6

Ответ 3

DT[order(-x)] работает так, как ожидалось. У меня есть data.table версии 1.9.4. Возможно, это было исправлено в последней версии.
Кроме того, я предлагаю синтаксис setorder(DT, -x) в соответствии с командами set *, такими как setnames, setkey