繁体   English   中英

基于 R 中另一列中的唯一值创建升序值列,并批量添加新数据

[英]Create column of ascending values based on unique values in another column in R with new data added in batches

我在 Python 中提出了一个类似的问题( 如何根据 pandas 另一列中的唯一值创建升序值列),并使脚本正常工作,但由于各种原因,我现在需要在 R 中实现相同的目标。 我还在这里增加了复杂性,希望能够定期向数据集添加新批次的数据。

我有一个样本列表,这些样本具有唯一的样本 ID 号(“Sample_ID”)。 数据集的每一行都是一个样本。 一些样品重复多次。 我想创建一组新的样本名称(“Sample_code”),当您使用前缀(例如“SAMP00001”、“SAMP00002”等)沿着行向下时,该名称从 1 上升。 我希望保留行的顺序(因为它们大致按样本收集的日期顺序排列)。 对于重复的样本,我希望为 Sample_code 给出的数字对应于样本 ID 出现的第一行,而不是表格下方的行(在样本收集中稍后出现)。

我的起始数据用 df1 说明:

# df1
Sample_ID <- c('123123','123456','123123','123789')
Date <- c('15/06/2019', '23/06/2019', '30/06/2019', '07/07/2019')
Variable <- c("blue","red","red","blue")
Batch <- 1
df1 <- data.frame(Sample_ID, Date, Variable, Batch)
df1

我想创建 df1b 中显示的 Sample_code 列:

# df1b
Sample_ID <- c('123123','123456','123123','123789')
Date <- c('15/06/2019', '23/06/2019', '30/06/2019', '07/07/2019')
Variable <- c("blue","red","red","blue")
Batch <- 1
Sample_code <- c('SAMP0001', 'SAMP0002', 'SAMP0001', 'SAMP0003')

df1b <- data.frame(Sample_ID, Date, Variable, Batch, Sample_code)
df1b

此时我会保存 df1b 以及用于下游处理的那些 Sample_code 名称。 增加的复杂性是因为我将收集一批新的样本 - 我们称之为 df2(第 2 批样本):

# df2
Sample_ID <- c('456789', '123654', '123123', '123789', '121212')
Date <- c('15/07/2019', '31/07/2019', '12/08/2019', '27/08/2019', '31/08/2019')
Variable <- c("blue", "red","blue", "red", "red")
Batch <- 2

df2 <- data.frame(Sample_ID, Date, Variable, Batch)
df2

我想将 df2 rbind 到 df1 的底部,并为新行生成更多 Sample_code 名称。 重要的是,新的 Sample_code 名称需要考虑 df1 中存在的任何 Sample_ID 重复项,但也不会更改当我只有 df1 时已经分配回的任何 Sample_code 名称。 此时的结果将是 df2b,如下所示:

# df2b
Sample_ID <- c('123123','123456','123123','123789','456789', '123654', '123123', '123789', '121212')
Date <- c('15/06/2019', '23/06/2019', '30/06/2019', '07/07/2019', '15/07/2019', '31/07/2019', '12/08/2019', '27/08/2019', '31/08/2019')
Variable <- c("blue","red","red","blue","blue", "red","blue", "red", "red")
Batch <- c(1,1,1,1,2,2,2,2,2)
Sample_code <- c('SAMP0001', 'SAMP0002', 'SAMP0001', 'SAMP0003', 'SAMP0004', 'SAMP0005', 'SAMP0001', 'SAMP0003', 'SAMP0006')
df2b <- data.frame(Sample_ID, Date, Variable, Batch, Sample_code)
df2b

然后我会以相同的方式添加第 3 批样本等等。

我很欣赏这个问题至少有两个阶段:1)使用唯一的 Sample_ID 值生成一个升序的 Sample_code 名称列表; 和 2) 以迭代方式添加批次样本。 但是因为第二点影响了我想要的 Sample_code 名称的功能,所以我在这里包含了两个阶段。

最后 - 理想情况下,我只想为此使用基础 R 和 tidyverse 包。

非常感谢任何帮助! 谢谢。

由于您需要在分配示例代码之前知道所有可能的示例 ID,因此可以考虑通过对所有示例数据帧调用rbind来颠倒顺序。 然后使用factor水平分配Sample_code 否则,为每个批次数据帧重新分配Sample_code

# BUILD A LIST OF DATA FRAMES BY CALLING lapply ON ITERATIVE PROCESS 
# df_list <- lapply(batch_iterable, method_to_build_sample)
df_list <- list(df1, df1b, df2)       # FOR THIS PARTICULAR POST

# RBIND ALL DFs TOGETHER
df2b <- do.call(rbind, df_list)

df2b <- within(df2b, {
    # CONVERT TO CHARACTER
    Sample_ID <- as.character(Sample_ID)

    # CONVERT TO FACTOR AT POSITIONED VALUES, THEN INTEGER FOR LEVEL NUMBER
    Sample_code <- as.character(as.integer(factor(Sample_ID, levels = unique(Sample_ID))))

    # RE-ASSIGN WITH SAMP AND LEADING ZEROS 
    Sample_code <- ifelse(nchar(Sample_code) == 1, paste0('SAMP000', Sample_code),
                          ifelse(nchar(Sample_code) == 2, paste0('SAMP00', Sample_code),
                                ifelse(nchar(Sample_code) == 3, paste0('SAMP0', Sample_code), NA)
                         )
                   )
})

df2b
#   Sample_ID       Date Variable Batch Sample_code
# 1    123123 15/06/2019     blue     1    SAMP0001
# 2    123456 23/06/2019      red     1    SAMP0002
# 3    123123 30/06/2019      red     1    SAMP0001
# 4    123789 07/07/2019     blue     1    SAMP0003
# 5    456789 15/07/2019     blue     2    SAMP0004
# 6    123654 31/07/2019      red     2    SAMP0005
# 7    123123 12/08/2019     blue     2    SAMP0001
# 8    123789 27/08/2019      red     2    SAMP0003
# 9    121212 31/08/2019      red     2    SAMP0006

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM