gpt4 book ai didi

r - 从字符向量中获取近似唯一的值

转载 作者:行者123 更新时间:2023-12-05 05:24:29 25 4
gpt4 key购买 nike

当数据表现良好时,识别 unique 值是很简单的。在这里,我正在寻找一种从字符向量中获取近似唯一值列表的方法。

x 是一个向量,实体的名称略有不同,例如Kentucky loader 可能显示为 Kentucky loadKentucky loader (additional info) 或类似内容。

x <- c("Kentucky load" ,                                                                                                            
"Kentucky loader (additional info)",
"CarPark Gifhorn (EAP)",
"Car Park Gifhorn (EAP) new 1.5.2012",
"Center Kassel (neu 01.01.2014)",
"HLLS Bremen (EAP)",
"HLLS Bremen (EAP) new 06.2013",
"Hamburg total sum (abc + TBL)",
"Hamburg total (abc + TBL) new 2012")

我要得到的是这样的:

c("Kentucky loader" ,                                                                                                            
"Car Park Gifhorn (EAP)",
"Center Kassel (neu 01.01.2014)",
"HLLS Bremen (EAP)",
"Hamburg total (abc + TBL)")

想法

  1. 计算所有字符串之间的一些相似性度量(例如 Levenshtein distance )
  2. 使用longest common subset method
  3. 不知何故 :( 根据此信息决定哪些字符串属于一起。

但我想这将是一项标准任务(对于那些经常处理“脏”数据的 R 用户),所以我假设会有一套标准方法来处理它。

是否有人有提示或是否有执行此操作的软件包?

最佳答案

正如@Jaap 所说,尝试使用 OpenRefine。 data carpentry course还不错。

如果您确实想留在 R 中,这里有一个针对您的示例的解决方案,使用 agrepl:

z <- sapply(x, function(z) agrepl(z, x, max.distance = 0.2))
apply(z, 1, function(myz) x[myz][which.min(nchar(x[myz]))])

它给出了为 x 的每个成员找到的字符中的最小匹配:

[1] "Kentucky load"                  "Kentucky load"                  "CarPark Gifhorn (EAP)"         
[4] "CarPark Gifhorn (EAP)" "Center Kassel (neu 01.01.2014)" "HLLS Bremen (EAP)"
[7] "HLLS Bremen (EAP)" "Hamburg total sum (abc + TBL)" "Hamburg total sum (abc + TBL)"

如果您想保持向量的顺序以匹配其他向量(或在数据帧的列上使用),这很好。

您可以在此输出上调用 unique 以获得所需的输出。

关于r - 从字符向量中获取近似唯一的值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34500166/

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