数据表的多类聚类中的嵌套聚类

如何对数据集中名称相似的字符串(如McDonald和Mc DOnald’s)进行聚类,如果字符串相同(如sam和其他也为sam),则如何基于值或价格再次进行聚类。例如,考虑一个包含10个元素的数据表

name           priceram               200shyam             150ram12              59gita               45ram 2                45 g11ita                23john2                32john                 7jonh21               8jonh                 38ram22                3

那么分组应为

ram                    200ram12                  59ram  2                 45ram22                   3john2                    32jonh                     37john                    7john21                   8gita                 45g11ita               23      

我使用了fuzzywuzzy和Levenheneitein距离进行字符串聚类,但它只能聚类字符串而无法聚类价格。如何先聚类字符串,如果相同再聚类价格?


回答:

你需要仔细平衡文本相似性和数值相似性的阈值。这没有简单的解决方案,除非你有非常庞大的数据,手动方法可能是最好的选择。

短字符串的文本相似性非常不可靠。

例如:“dog”和“fog”只差一个字母,但不太可能是打字错误。它们的Levenshtein距离为1,是最小的非零值!因此,如果你依赖Levenshtein,你会得到很多误报——如果你手动验证它们还可以,但不适合自动处理。

因此,你至少需要使用一些了解(a)现有单词,这些单词不太可能是拼写错误,(b)常见的拼写错误,(c)音似性来估计一个单词是否可能拼写错误,(d)键盘相似性,一个单词是否可能被误打…

Related Posts

L1-L2正则化的不同系数

我想对网络的权重同时应用L1和L2正则化。然而,我找不…

使用scikit-learn的无监督方法将列表分类成不同组别,有没有办法?

我有一系列实例,每个实例都有一份列表,代表它所遵循的不…

f1_score metric in lightgbm

我想使用自定义指标f1_score来训练一个lgb模型…

通过相关系数矩阵进行特征选择

我在测试不同的算法时,如逻辑回归、高斯朴素贝叶斯、随机…

可以将机器学习库用于流式输入和输出吗?

已关闭。此问题需要更加聚焦。目前不接受回答。 想要改进…

在TensorFlow中,queue.dequeue_up_to()方法的用途是什么?

我对这个方法感到非常困惑,特别是当我发现这个令人费解的…

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注