Vba 潜在重复检测,具有3个严重级别

Vba 潜在重复检测,具有3个严重级别,vba,excel,duplicates,Vba,Excel,Duplicates,我想做一个程序,检测3个严重级别的潜在重复。 让我考虑我的数据只有两列,但有数千行。 第二列中的数据仅用逗号分隔。数据示例: Number | Material 1 | helmet,valros,42 2 | helmet,iron,knight 3 | valros,helmet,42 4 | knight,helmet 5 | valros,helmet,42 6 | plain,helmet 7 | helmet, l

我想做一个程序,检测3个严重级别的潜在重复。 让我考虑我的数据只有两列,但有数千行。 第二列中的数据仅用逗号分隔。数据示例:

Number | Material
1      | helmet,valros,42
2      | helmet,iron,knight
3      | valros,helmet,42
4      | knight,helmet
5      | valros,helmet,42
6      | plain,helmet
7      | helmet, leather
我的3个级别是:

非常高:A、B、CvsA、B、C

高:A、B、CvsB、C、A

soso:A、B、CvsA、B

到目前为止,我只能进入第一级,我不知道如何进入第二级和第三级

我试过的

Sub duplicates_separation()

    Dim duplicate(), i As Long
    Dim delrange As Range, cell As Long
    Dim shtIn As Worksheet, shtOut As Worksheet



     Set shtIn = ThisWorkbook.Sheets("input")
    Set shtOut = ThisWorkbook.Sheets("output")

    x = 2
    y = 1

    Set delrange = shtIn.Range("b1:b10000")  'set your range here

   ReDim duplicate(0)
'search duplicates in 2nd column
    For cell = 1 To delrange.Cells.Count
        If Application.CountIf(delrange, delrange(cell)) > 1 Then
            ReDim Preserve duplicate(i)
            duplicate(i) = delrange(cell).Address
            i = i + 1
        End If
    Next


        'print duplicates
    For i = UBound(duplicate) To LBound(duplicate) Step -1
    shtOut.Cells(x, 1).EntireRow.Value = shtIn.Range(duplicate(i)).EntireRow.Value


End Sub
程序检测到的重复项:

3      | valros,helmet,42
 5      | valros,helmet,42
我所期望的是:

Number | Material
1      | helmet,valros,42
3      | valros,helmet,42
5      | valros,helmet,42
4      | knight,helmet
2      | helmet,iron,knight        
我有一个检测lv 2副本的想法,但我认为这将是如此复杂,使程序运行缓慢

  • 使用“文本转换为列”命令将第2列转换为列
  • 从A到Z对列进行排序(按字母顺序)
  • 连接列
  • 在检测lv 1的重复项时是否进行计数
  • 是否有办法检测第二级和第三级副本


    更新

    昨天我去朋友家咨询这个问题,但他的解决方案是JAVA语言的..>我不明白

    public class ali {
    
        static void sPrint(String[] Printed) {
            for (int iC = 0; iC < Printed.length; iC++) {
                System.out.print(String.valueOf(Printed[iC]) + " | ");
            }
            System.out.println();
        }
    
        public static void main(String Args[]) {
            int defaultLength = 10;
            int indexID = 0;
            int indexDesc = 1;
            String[] DETECTORP1 = new String[defaultLength];
            String[] DETECTORP2 = new String[defaultLength];
            String[] DETECTORP3 = new String[defaultLength];
            String[] DETECTORP4 = new String[defaultLength];
            String[][] theString = new String[5][2];
            theString[0] = new String[]{"1", "A, B, C, D"};
            theString[1] = new String[]{"2", "A, B, C, D"};
            theString[2] = new String[]{"3", "A, B, C, D, E"};
            theString[3] = new String[]{"4", "A, B, D, C, E"};
            theString[4] = new String[]{"5", "A, B, D, C, E, F"};
            int P1 = 0;
            int P2 = 0;
            int P3 = 0;
            int P4 = 0;
            for (int iC = 0; iC < theString.length; iC++) {
                System.out.println(theString[iC][indexID] + " -> " + theString[iC][indexDesc]);
            }
            for (int iC = 0; iC < theString.length; iC++) {
                int LEX;
                String theReference[] = theString[iC][indexDesc].replace(",", ";;").split(";;");
                for (int iD = 0; iD < theString.length; iD++) {
                    if (iC != iD) {
                        String theCompare[] = theString[iD][1].replace(",", ";;").split(";;");
                        if (theReference.length == theCompare.length) {
                            LEX=0;
                            int theLength = theReference.length;
                            for (int iE = 0; iE < theLength; iE++) {
                                if (theReference[iE].equals(theCompare[iE])) {
                                    LEX += 1;
                                }
                            }
                            if (LEX == theLength) {
                                DETECTORP1[P1] = theString[iC][indexID] + " WITH " + theString[iD][indexID];
                                P1 += 1;
                            } else {
                                LEX = 0;
                                for (int iF = 0; iF < theReference.length; iF++) {
                                    for (int iG = 0; iG < theCompare.length; iG++) {
                                        if (theReference[iF].equals(theCompare[iG])) {
                                            LEX += 1;
                                            break;
                                        }
                                    }
                                }
                                if (LEX == theReference.length) {
                                    DETECTORP2[P2] = theString[iC][indexID] + " WITH " + theString[iD][indexID];
                                    P2 += 1;
                                }
    
                            }
    
                        } else {
                            LEX = 0;
                            if (theReference.length > theCompare.length) {
                                for (int iF = 0; iF < theReference.length; iF++) {
                                    for (int iG = 0; iG < theCompare.length; iG++) {
                                        if (iG == iF) {
                                            if (theReference[iF].equals(theCompare[iF])) {
                                                LEX += 1;
                                                break;
                                            }
                                        }
                                    }
                                }
                                if (LEX <= theReference.length && LEX >= theCompare.length) {
                                    DETECTORP3[P3] = theString[iC][indexID] + " WITH " + theString[iD][indexID];
                                    P3 += 1;
                                }
                            } else {
                                LEX =0;
                                for (int iF = 0; iF < theCompare.length; iF++) {
                                    for (int iG = 0; iG < theReference.length; iG++) {
                                        if (iG == iF) {
                                            if (theCompare[iF].equals(theReference[iF])) {
                                                LEX += 1;
                                            //    System.out.println(theReference[iG] + "==" + theCompare[iG]);
                                                break;
                                            }
                                        }
                                    }
                                }
                                if (LEX <= theCompare.length && LEX >= theReference.length) {
                                    DETECTORP3[P3] = theString[iC][indexID] + " WITH " + theString[iD][indexID];
                                    P3 += 1;
                                }
                            }
    
                        }
                    }
    
                }
    
            }
            sPrint(DETECTORP1);
            sPrint(DETECTORP2);
            sPrint(DETECTORP3);
        }
    }
    
    公共类阿里{
    静态void sPrint(字符串[]已打印){
    用于(int iC=0;iC”+字符串[iC][indexDesc]);
    }
    for(int iC=0;iCcompare.length){
    for(int iF=0;iFH    helmet
    K    knight
    I    iron
    $    Leather
    ^    Valros
    ╔    Plain
    ¢    Whatever
    etc.
    
    HIK = helmet,iron,knight
    ¢H  = plain,helmet
    
    Debug.Print LevenshteinDistance("HIK","¢H")
    'returns 3