gpt4 book ai didi

r - 如何撤消 data.table 中的 setkey 排序?

转载 作者:行者123 更新时间:2023-12-03 22:36:49 24 4
gpt4 key购买 nike

假设我有一个数据表 DT,我用 set 键更改了顺序

setkey(DT,mykey)

然后,也许我会从另一张 table 上加入一些东西。
DT=DT2[DT]

有没有办法恢复我原来的行排序?我知道,我可以通过在使用 setkey 之前显式包含索引来实现。
N=Nrow(DT)
DT[,orig_index:=1:N]
setkey(DT,mykey)
DT=DT2[DT]
setkey(DT,orig_index)
DT[,orig_index:=NULL]

有没有更简单的方法?如果我用 order 而不是 set key 来做这件事,这会更简单一些。
o=order(DT$mykey)
uo=order(o)
setkey(DT,mykey)
DT=DT2[DT]
DT=DT[uo,]

我想如果 setkey 可以用这样的东西反转会很酷
setkey(DT,mykey,save.unset=T)
DT=DT2[DT]
unsetkey(DT)

这里 save.unset=T 会告诉 data.table 保存最后的重新排序,以便可以反转。

更好,也许
setkey(DT, reorder=F)
DT=DT2[DT]

此选项将告诉 data.table 使用键排序或其他任何方式,而无需实际更改 DT 的顺序。不确定这是否可能或自然实现。

最佳答案

同意。这就是我们所说的二级 key ,计划是添加 set2key做到这一点。现在可以做手动辅助键了。但这与您在问题中的情况非常相似。它已经出现了很多。

FR#1007 Build in secondary keys

和一些例子:

https://stackoverflow.com/a/13660454/403310
https://stackoverflow.com/a/13969805/403310

关于r - 如何撤消 data.table 中的 setkey 排序?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15552181/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com