대소문자를 구분하지 않는 XPath contain() 함수
XPath에서 contain() 함수는 대소문자를 구분합니다. 그러나 이 제한 사항을 해결할 수 있는 방법이 있습니다.
방법 1: 문자 번역
이 방법에는 하위 문자열을 확인하기 전에 문자를 소문자 또는 대문자로 변환하는 작업이 포함됩니다.
/html/body//text()[ contains( translate(., 'ABCDEFGHIJKLMNOPQRSTUVWXYZ', 'abcdefghijklmnopqrstuvwxyz'), 'test' ) ]
이것은 하위 문자열 "test"를 확인하기 전에 텍스트의 모든 대문자를 소문자로 변환합니다.
방법 2: 동적 XPath 표현식
JavaScript와 같은 스크립팅 언어를 사용하면 대소문자를 구분하지 않는 동적 XPath 표현식을 구성할 수 있습니다.
function xpathPrepare(xpath, searchString) {
return xpath.replace("$u", searchString.toUpperCase())
.replace("$l", searchString.toLowerCase())
.replace("$s", searchString.toLowerCase());
}
xp = xpathPrepare("//text()[contains(translate(., '$u', '$l'), '$s')]", "Test");
이것은 자리 표시자를 대체합니다. 검색 문자열의 대문자, 소문자 및 소문자 버전이 있는 XPath 표현식에서.
추가 고려 사항
부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.
Copyright© 2022 湘ICP备2022001581号-3