> 웹 프론트엔드 > JS 튜토리얼 > 대소문자를 구분하지 않는 XPath Contains() 검색을 수행하는 방법은 무엇입니까?

대소문자를 구분하지 않는 XPath Contains() 검색을 수행하는 방법은 무엇입니까?

DDD
풀어 주다: 2024-10-22 20:33:39
원래의
842명이 탐색했습니다.

How to Perform Case-Insensitive XPath Contains() Searches?

대소문자를 구분하지 않는 XPath Contains()

질문:

XPath를 사용하여 확인하는 경우 /html/body//text()[contains(.,'test')] 표현식과 같이 텍스트 노드 내에 문자열이 존재하는 경우 검색은 대/소문자를 구분합니다. JavaScript용 XPath에서 어떻게 대소문자를 구분하지 않고 검색할 수 있습니까?

답변:

XPath 1.0에서 대소문자를 구분하지 않는 비교를 수행하는 간단한 방법은 없지만, 비슷한 결과를 얻을 수 있는 기술이 있습니다:

  1. 대소문자 번역: 번역() 함수를 사용하여 텍스트 노드와 검색 문자열을 단일 대소문자 또는 대문자로 변환합니다. 또는 그 이하. 예:
/html/body//text()[contains(translate(., 'ABCDEFGHIJKLMNOPQRSTUVWXYZ', 'abcdefghijklmnopqrstuvwxyz'), 'test')]
로그인 후 복사

이 방법에서는 사용된 알파벳이 미리 알려져 있다고 가정하므로 나타날 수 있는 악센트 문자를 모두 포함합니다.

  1. 동적 XPath 표현식: JavaScript와 같은 호스트 언어를 사용하여 동적 XPath 표현식을 만듭니다. 검색 문자열을 포함() 절에서 상위, 하위 및 원래 형식으로 바꾸십시오.
<code class="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");
// -> "//text()[contains(translate(., 'TEST', 'test'), 'test')]"</code>
로그인 후 복사

이렇게 하면 사용된 문자 세트에 관계없이 대소문자를 구분하지 않고 검색할 수 있습니다.

이러한 방법은 검색 문자열의 작은따옴표를 올바르게 처리하지 못할 수 있다는 점에 유의하세요. 특수 문자가 있는 경우에는 대체 접근 방식이 필요할 수 있습니다.

위 내용은 대소문자를 구분하지 않는 XPath Contains() 검색을 수행하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿