首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >根据其他数值列添加排名列

根据其他数值列添加排名列
EN

Stack Overflow用户
提问于 2017-03-05 22:43:42
回答 2查看 132关注 0票数 0

我在创建新的排名列时遇到了麻烦。我有以下数据:

代码语言:javascript
复制
Title             Cat. Rank     
The Da Vinci Code Book 19
The Da Vinci Code Book 19
The Da Vinci Code Book 19
Sisterhood....    Book 21
Book X            Book 34
Book X            Book 34

我需要基于当前的rank列创建一个新的rank列,其中达芬奇代码在具有达芬奇代码的所有行中都得到1。当出现新标题时,排名应改为2,以此类推。

我已经尝试了很多不同的排名,例如:

代码语言:javascript
复制
  dt.reviews.books.new[,sales_rank_cat:=rank(title, ties.method="first"),by=title]

但这会为每个标题分配一个1。

EN

回答 2

Stack Overflow用户

发布于 2017-03-05 22:56:01

我听起来就像你在说DaVinci代码将总是得到1,而其他的已经在排名顺序中,这样下面的标题将得到2,3,....n。

代码语言:javascript
复制
library(data.table)
newDF <- data.table(dt.reviews.books.new) %>%
         newDF[, newRank := 1:.N, by = "Title"]

再次提醒您,此排名假设您的书目当前按排名顺序排列。如果您的新排名是基于当前排名,我会使用sort()arrange()来按Rank排序。

票数 0
EN

Stack Overflow用户

发布于 2017-03-05 23:08:28

代码语言:javascript
复制
library(dplyr)
df %>% mutate(rank = dense_rank((rank)))

如果对排序号有意义,你可以使用desc

代码语言:javascript
复制
df %>% mutate(rank = dense_rank(desc(rank)))
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/42609741

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档