LINQ를 사용한 영숫자 정렬
숫자 값이 포함된 문자열을 처리할 때 LINQ의 기본 알파벳 정렬로는 원하는 결과가 나오지 않을 수 있습니다. 다음 예를 고려하십시오.
string[] partNumbers = new string[] { "ABC10", "ABC1","ABC2", "ABC11","ABC10", "AB1", "AB2", "Ab11" }; var result = partNumbers.OrderBy(x => x);
예상 결과는 다음과 같이 문자열을 정렬합니다.
AB1 AB2 AB11 ...
그러나 기본 문자열 순서는 사전식 순서를 따르기 때문에 실제 결과는 다릅니다. 이는 숫자 값이 왼쪽에서 오른쪽으로 비교되어 다음 순서로 이어진다는 것을 의미합니다.
AB1 Ab11 AB2 ABC1 ABC10 ABC10 ABC11 ABC2
원하는 영숫자 정렬을 달성하려면 비교 논리를 수정해야 합니다. 각 문자열의 숫자 부분을 특정 개수의 0으로 채울 수 있습니다. 이렇게 하면 길이에 관계없이 숫자 값이 공정하게 비교됩니다.
public static string PadNumbers(string input) { return Regex.Replace(input, "[0-9]+", match => match.Value.PadLeft(10, '0')); } var result = partNumbers.OrderBy(x => PadNumbers(x));
이 수정된 순서를 사용하면 문자열의 숫자 부분이 패딩된 값을 기준으로 비교되어 다음과 같은 올바른 순서가 적용됩니다.
AB1 AB2 AB11 ...
이 접근 방식에서는 입력 숫자의 최대 자릿수를 가정합니다. 지정된 패딩보다 자릿수가 많은 숫자가 있는 경우 정렬이 정확하지 않을 수 있습니다.
위 내용은 LINQ는 숫자가 포함된 문자열의 올바른 영숫자 정렬을 어떻게 달성할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!