"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > XPath 1.0에서 대소문자를 구분하지 않는 contain() 기능을 달성하는 방법은 무엇입니까?

XPath 1.0에서 대소문자를 구분하지 않는 contain() 기능을 달성하는 방법은 무엇입니까?

2024년 11월 20일에 게시됨
검색:492

How to Achieve Case-Insensitive contains() Functionality in XPath 1.0?

XPath의 대소문자를 구분하지 않음 contain()

XSLT 또는 기타 DOM 순회 애플리케이션에서 대소문자를 구분하는 문자열 비교로 XPath 쿼리를 수행하면 제한적이다. 그러나 XPath 1.0에서는 대소문자를 구분하지 않는 contain() 기능을 구현하는 것이 가능합니다.

1. 번역 기반 방법(XPath 1.0)

대소문자 구분 및 대소문자 구분 없는 문자열 변형을 모두 일치시키려면 다음과 같이 번역() 함수를 사용합니다.

/html/body//text()[
  contains(
    translate(., 'ABCDEFGHIJKLMNOPQRSTUVWXYZ', 'abcdefghijklmnopqrstuvwxyz'),
    'test'
  )
]

이 방법은 모든 대문자를 소문자로 효과적으로 변환하여 대소문자를 구분하지 않는 비교를 가능하게 합니다. 그러나 예상되는 문자 집합에 대한 지식이 필요합니다.

2. JavaScript 지원 동적 XPath 생성

XPath 표현식 조작이 가능한 경우 JavaScript를 사용하여 검색 문자열을 대문자 및 소문자 변형으로 동적으로 바꿀 수 있습니다.

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 2.0 채택과 같은 다른 솔루션을 고려해보세요.

릴리스 선언문 이 글은 1729588936에서 재인쇄되었습니다. 침해 내용이 있는 경우, [email protected]으로 연락하여 삭제하시기 바랍니다.
최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3