首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >基于重复ID创建唯一ID

基于重复ID创建唯一ID
EN

Stack Overflow用户
提问于 2021-06-18 10:15:36
回答 2查看 73关注 0票数 0

我收到了一位同事的一些数据,他正在处理记录在几条横断面上的动物观察。但是,我的同事使用相同的三个ID代码来识别每个横断面: 1、7、13和19。我想用唯一的ID替换重复的ID。这张图片显示了我想要做的事情:

以下是相应的代码:

代码语言:javascript
复制
example_data<-structure(list(ID_Transect = c(1L, 1L, 1L, 1L, 1L, 1L, 7L, 7L, 
                                             7L, 7L, 7L, 7L, 13L, 13L, 13L, 13L, 13L, 13L, 19L, 19L, 19L, 
                                             19L, 19L, 19L, 1L, 1L, 1L, 1L, 1L, 1L, 7L, 7L, 7L, 7L, 7L, 7L), 
                             transect_id = c(1L, 1L, 1L, 1L, 1L, 1L, 2L, 2L, 2L, 2L, 2L, 
                   2L, 3L, 3L, 3L, 3L, 3L, 3L, 4L, 4L, 4L, 4L, 4L, 4L, 5L, 5L, 5L, 
                   5L, 5L, 5L, 6L, 6L, 6L, 6L, 6L, 6L)), class = "data.frame", row.names = c(NA, 
                                                                                             -36L))
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2021-06-18 10:25:43

你可以用data.table rleid -

代码语言:javascript
复制
example_data$transect_id <- data.table::rleid(example_data$ID_Transect)
#[1] 1 1 1 1 1 1 2 2 2 2 2 2 3 3 3 3 3 3 4 4 4 4 4 4 5 5 5 5 5 5 6 6 6 6 6 6

在R基中,我们可以使用rle -

代码语言:javascript
复制
with(rle(example_data$ID_Transect), rep(seq_along(values), lengths))

或者diff + cumsum -

代码语言:javascript
复制
cumsum(c(TRUE, diff(example_data$ID_Transect) != 0))
票数 2
EN

Stack Overflow用户

发布于 2021-06-18 16:48:48

我们也可以

代码语言:javascript
复制
library(data.table)
setDT(example_data)[, transect_id := rleid(ID_Transect)]
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/68033379

复制
相关文章

相似问题

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