찾다

PHP DOM: Using XPath

코어 포인트

XPath는 기능을 작성하는 더 간단하고 깨끗한 방법을 제공하고 쿼리를 작성하고 XML 데이터를 필터하는 데 필요한 코드의 양을 줄이는 XML 문서를 쿼리하기위한 구문입니다.

xpath 쿼리는 와 라는 두 가지 함수를 사용하여 수행 할 수 있습니다. 두 가지 모두 쿼리를 수행하지만 차이점은

를 사용할 수 있으며 사각형 브래킷의 노드 값을 비교할 수 있으며, "/.."는 부모 요소를 원한다는 것을 의미합니다 (즉, 하나의 노드를 위쪽으로 이동). XPath 쿼리는 두 가지 함수 중 하나를 사용하여 수행 할 수 있습니다. 둘 다 쿼리를 수행하지만 차이점은 반환 결과 유형입니다. 는 항상

를 반환하고
<!DOCTYPE library [
  <!ELEMENT library (book*)>
  <!ELEMENT book (title, author, genre, chapter*)>
  <!ATTLIST book isbn ID #REQUIRED>
  <!ELEMENT title (#PCDATA)>
  <!ELEMENT author (#PCDATA)>
  <!ELEMENT genre (#PCDATA)>
  <!ELEMENT chapter (chaptitle,text)>
  <!ATTLIST chapter position NMTOKEN #REQUIRED>
  <!ELEMENT chaptitle (#PCDATA)>
  <!ELEMENT text (#PCDATA)>
]>
는 가능한 한 입력 된 결과를 반환합니다. 예를 들어, XPath Query가 실제 책 자체가 아닌 특정 저자가 작성한 책 수를 반환하면
<?xml version="1.0" encoding="utf-8"?>
<library>
  <book isbn="isbn1234">
    <title>A Book</title>
    <author>An Author</author>
    <genre>Horror</genre>
    <chapter position="first">
      <chaptitle>chapter one</chaptitle>
      <text></text>
    </chapter>
  </book>
  <book isbn="isbn1235">
    <title>Another Book</title>
    <author>Another Author</author>
    <genre>Science Fiction</genre>
    <chapter position="first">
      <chaptitle>chapter one</chaptitle>
      <text>Sit Dolor Amet...</text>
    </chapter>
  </book>
</library>
는 를 반환합니다. 는 번호를 직접 반환하므로 노드에서 데이터를 추출하지 않고도 즉시 사용할 수 있습니다.

XPath의 코드 및 속도 장점 특정 저자가 쓴 책 수를 반환하면서 빠른 시연을하자. 먼저 실행 가능한 접근 방식을 살펴 보지만 XPath를 사용하지 않습니다. 이것은 XPath를 사용하지 않고이 작업을 수행하는 방법과 XPath가 왜 그렇게 강력한 지 보여주는 것입니다.

다음 방법은 동일한 결과를 달성하지만 XPath를 사용하여 특정 저자가 작성한 책을 선택합니다.
<!DOCTYPE library [
  <!ELEMENT library (book*)>
  <!ELEMENT book (title, author, genre, chapter*)>
  <!ATTLIST book isbn ID #REQUIRED>
  <!ELEMENT title (#PCDATA)>
  <!ELEMENT author (#PCDATA)>
  <!ELEMENT genre (#PCDATA)>
  <!ELEMENT chapter (chaptitle,text)>
  <!ATTLIST chapter position NMTOKEN #REQUIRED>
  <!ELEMENT chaptitle (#PCDATA)>
  <!ELEMENT text (#PCDATA)>
]>
이번에는 PHP가 저자 값을 테스트 할 필요가 없음에 유의하십시오. 그러나 한 걸음 더 나아가 XPath 함수

를 사용 하여이 경로의 발생 수를 계산할 수 있습니다.

<?xml version="1.0" encoding="utf-8"?>
<library>
  <book isbn="isbn1234">
    <title>A Book</title>
    <author>An Author</author>
    <genre>Horror</genre>
    <chapter position="first">
      <chaptitle>chapter one</chaptitle>
      <text></text>
    </chapter>
  </book>
  <book isbn="isbn1235">
    <title>Another Book</title>
    <author>Another Author</author>
    <genre>Science Fiction</genre>
    <chapter position="first">
      <chaptitle>chapter one</chaptitle>
      <text>Sit Dolor Amet...</text>
    </chapter>
  </book>
</library>
우리는 PHP를 사용하여 힘든 필터링을 수행 할 필요없이 필요한 정보를 검색하기 위해 XPath의 한 줄만 필요합니다. 사실, 이것은이 기능을 작성하는 더 쉽고 간결한 방법입니다! 는 마지막 예제에서 사용됩니다. 함수 가 입력 된 결과를 반환하기 때문입니다.

를 사용하면 count()가 반환되지만 빈 목록이라는 것을 알 수 있습니다. 이것은 코드를 더 간결하게 만들뿐만 아니라 속도의 장점도 있습니다. 버전 1은 버전 2보다 평균 속도가 30% 더 빠르지 만 버전 3은 버전 2보다 약 10% 빠릅니다 (버전 1보다 약 15% 더 빠릅니다). 이러한 측정은 서버와 쿼리에 따라 다르지만 순수한 XPath를 사용하면 상당한 속도 이점을 가져 오는 동시에 코드를 쉽게 읽고 유지 관리 할 수 ​​있습니다.

//library/book
xpath 함수

xpath는 많은 기능을 사용할 수 있으며 사용 가능한 기능을 자세히 설명하는 많은 우수한 리소스가 있습니다. 자신이 를 반복하거나 evaluate()를 비교하면 많은 PHP 코드를 제거하는 XPath 함수를 찾을 수 있습니다. 당신은 count() 함수의 사용을 보았습니다. 함수를 사용하여 주어진 ISBN과 함께 책의 제목을 반환합시다. 사용해야하는 XPath 표현식은 다음과 같습니다 query() 여기에서 검색 할 값은 인용문으로 둘러싸여 있으며 쉼표로 구분 된 용어가 필요하지 않습니다. DOMNodeList

XPath에서 복잡한 기능을 실행하는 것은 비교적 간단합니다.

XPATH 에서 PHP 함수를 사용하는 때때로 표준 XPath 기능이 제공 할 수없는 더 강력한 기능이 필요할 수도 있습니다. 다행히도 PHP DOM을 사용하면 PHP의 기능을 XPath 쿼리에 통합 할 수 있습니다. 책 제목에서 단어 수를 반환하는 것을 고려해 봅시다. 가장 간단한 기능은 다음과 같은 방법을 쓸 수 있습니다.

<!DOCTYPE library [
  <!ELEMENT library (book*)>
  <!ELEMENT book (title, author, genre, chapter*)>
  <!ATTLIST book isbn ID #REQUIRED>
  <!ELEMENT title (#PCDATA)>
  <!ELEMENT author (#PCDATA)>
  <!ELEMENT genre (#PCDATA)>
  <!ELEMENT chapter (chaptitle,text)>
  <!ATTLIST chapter position NMTOKEN #REQUIRED>
  <!ELEMENT chaptitle (#PCDATA)>
  <!ELEMENT text (#PCDATA)>
]>
그러나 그러나 함수

를 xpath 쿼리에 직접 통합 할 수도 있습니다. 이를 위해서는 여러 단계를 완료해야합니다. 먼저 XPath 객체를 사용하여 네임 스페이스를 등록해야합니다. XPath 쿼리의 PHP 함수는 ""로 시작하여 사용하려는 기능의 이름을 괄호로 둘러싸고 있습니다. 또한, 정의 할 네임 스페이스는 str_word_count()입니다. 네임 스페이스는 다른 값으로 설정해야합니다. 그런 다음 PHP에게 "php:functionString 이 모든 것을 함께 모으고 http://php.net/xpath : 의 다음과 같은 상환을 받으십시오. registerPHPFunctions() 노드의 텍스트를 제공하려면 xpath 함수 호출 할 필요가 없습니다. php: 메소드가 자동으로 수행합니다. 그러나 다음은 유효합니다

PHP 함수는 PHP와 함께 제공되는 함수에만 국한되지 않습니다. 자신의 기능을 정의하고 XPath에서 제공 할 수 있습니다. 유일한 차이점은 함수를 정의 할 때 ""대신 ""을 사용하는 것입니다. 또한 함수 자체 또는 정적 방법 만 제공 할 수 있습니다. 호출 인스턴스 방법은 지원되지 않습니다. 클래스의 범위를 벗어난 일반 함수를 사용하여 기본 기능을 시연하겠습니다. 우리가 사용할 함수는 "George Orwell"의 책만 반환합니다. 쿼리에 포함하려는 각 노드에 대해 를 반환해야합니다.
<?xml version="1.0" encoding="utf-8"?>
<library>
  <book isbn="isbn1234">
    <title>A Book</title>
    <author>An Author</author>
    <genre>Horror</genre>
    <chapter position="first">
      <chaptitle>chapter one</chaptitle>
      <text></text>
    </chapter>
  </book>
  <book isbn="isbn1235">
    <title>Another Book</title>
    <author>Another Author</author>
    <genre>Science Fiction</genre>
    <chapter position="first">
      <chaptitle>chapter one</chaptitle>
      <text>Sit Dolor Amet...</text>
    </chapter>
  </book>
</library>

함수로 전달 된 인수는 의 배열입니다. 이 함수는 배열을 반복하고 테스트 할 노드를 로 반환 해야하는지 결정합니다. 이 예에서 테스트 할 노드는 getNumberOfWords()이며, 이는

를 사용하여 결정합니다. 이제 우리는
//library/book
:

메소드를 만들 수 있습니다 text() registerPHPFunctions() 가 정적 메소드라면 xpath 쿼리를 수정하여 읽어야합니다.

//library/book/author[text() = "An Author"]/..
실제로 이러한 모든 기능은 XPath로만 쉽게 작성할 수 있지만이 예제는 XPath 쿼리를 확장하여 더 복잡하게 만드는 방법을 보여줍니다. XPath에서 객체 메소드를 호출 할 수 없습니다. XPath 쿼리를 완료하기 위해 특정 객체 속성 또는 메소드에 액세스해야한다면 가장 좋은 솔루션은 XPath를 사용하여 수행 할 수있는 부품을 완료 한 다음 객체 메소드 또는 속성을 사용하여 생성 된

를 필요에 따라 필요로하는 것입니다. . php:function 요약 php:functionString true XPath는 XML 데이터를 처리 할 때 코드 작성 및 코드 실행 속도를 높이는 좋은 방법입니다. 공식 DOM 사양의 일부는 아니지만 PHP DOM이 제공하는 추가 기능을 사용하면 사용자 지정 기능으로 표준 XPATH 기능을 확장 할 수 있습니다. 이것은 매우 강력한 기능이며 XPath 기능에 더 익숙해지면서 자신이 점점 더 적게 의존 할 수 있습니다.

(Fotolia의 그림) XPATH 를 가진 php dom에 대한 faqs (FAQ) XPath 란 무엇이며 PHP DOM에서 어떻게 작동합니까?

XPath (XML Path Language)는 XML 문서에서 노드를 선택하는 데 사용되는 쿼리 언어입니다. PHP DOM에서 XPath는 XML 문서에서 요소 및 특성을 가로 지르는 데 사용됩니다. 이름별로 노드를 선택하거나, 속성 값으로 노드를 선택하거나, 문서의 위치별로 노드를 선택하는 등 다양한 방법으로 XML 문서의 특정 부분을 찾고 선택할 수 있습니다. 이를 통해 PHP에서 XML 데이터를 구문 분석하고 조작하기위한 강력한 도구가됩니다.

domxpath 인스턴스를 만드는 방법은 무엇입니까? domxpath 인스턴스를 만들려면 먼저 domdocument 클래스의 인스턴스를 만들어야합니다. domdocument 객체를 얻은 후에는 domdocument 객체를 domxpath 생성자에 전달하여 새 domxpath 객체를 만들 수 있습니다. 예는 다음과 같습니다. XPath를 사용하여 노드를 선택하는 방법은 무엇입니까?

domxpath 객체의 메소드를 사용하여 노드를 선택할 수 있습니다.

메소드는 XPath 표현식을 매개 변수로 취하고 표현식과 일치하는 모든 노드를 포함하는 domnodelist 객체를 반환합니다. 예를 들면 :

이것은 요소의 자식 요소 인 모든

요소를 선택합니다.

domxpath에서

방법의 차이점은 무엇입니까?

<!DOCTYPE library [
  <!ELEMENT library (book*)>
  <!ELEMENT book (title, author, genre, chapter*)>
  <!ATTLIST book isbn ID #REQUIRED>
  <!ELEMENT title (#PCDATA)>
  <!ELEMENT author (#PCDATA)>
  <!ELEMENT genre (#PCDATA)>
  <!ELEMENT chapter (chaptitle,text)>
  <!ATTLIST chapter position NMTOKEN #REQUIRED>
  <!ELEMENT chaptitle (#PCDATA)>
  <!ELEMENT text (#PCDATA)>
]>
방법은 모두 XPath 표현식을 평가하는 데 사용됩니다. 차이점은 그들이 반환하는 결과 유형입니다.

메소드는 xpath 표현식과 일치하는 모든 노드의 domnodelist를 반환합니다. 반면에 는 XPath 표현식에 따라 부울, 번호 또는 문자열과 같은 유형의 결과를 반환합니다. 표현식 결과가 노드 세트 인 경우

는 domnodelist를 반환합니다.

xpath 쿼리에서 네임 스페이스를 처리하는 방법은 무엇입니까? query()

xpath 쿼리에서 네임 스페이스를 처리하려면 메소드를 사용하여 DomxPath 객체와 네임 스페이스를 등록해야합니다. 이 방법에는 접두사와 네임 스페이스 URI의 두 가지 매개 변수가 있습니다. 네임 스페이스를 등록한 후 XPath 쿼리에서 접두사를 사용할 수 있습니다. 예를 들면 : query()

xpath를 사용하여 속성을 선택하는 방법은 무엇입니까?
<?xml version="1.0" encoding="utf-8"?>
<library>
  <book isbn="isbn1234">
    <title>A Book</title>
    <author>An Author</author>
    <genre>Horror</genre>
    <chapter position="first">
      <chaptitle>chapter one</chaptitle>
      <text></text>
    </chapter>
  </book>
  <book isbn="isbn1235">
    <title>Another Book</title>
    <author>Another Author</author>
    <genre>Science Fiction</genre>
    <chapter position="first">
      <chaptitle>chapter one</chaptitle>
      <text>Sit Dolor Amet...</text>
    </chapter>
  </book>
</library>
기호와 속성 이름을 사용하여 xpath에서 속성을 선택할 수 있습니다. 예를 들어, 요소의 모든 속성을 ​​선택하려면 다음 xpath 표현식을 사용할 수 있습니다.

PHP DOM에서 XPath 함수를 사용하는 방법은 무엇입니까? <book></book> XPath는 XPath 표현식에서 사용할 수있는 많은 기능을 제공합니다. 이러한 기능은 문자열, 숫자, 노드 세트 등을 조작하는 데 사용될 수 있습니다. php dom에서 xpath 함수를 사용하려면 xpath 표현식에 함수를 포함 시키십시오. 예를 들어, 값이 30보다 큰 가격 요소를 가진 모든 <title></title> 요소를 선택하려면 다음과 같이

기능을 사용할 수 있습니다.

PHP DOM에서 HTML 문서와 함께 XPath를 사용할 수 있습니까?

예, PHP dom에서 html 문서와 함께 xpath를 사용할 수 있습니다. 그러나 HTML이 항상 잘 형성된 XML은 아니기 때문에 HTML과 함께 XPath를 사용하는 데 문제가있을 수 있습니다. 이러한 문제를 피하기 위해 DomDocument 클래스의

메소드를 사용하여 HTML 문서를로드 할 수 있습니다. 이 메소드는 HTML을 구문 분석하고 형식화 오류를 수정하여 생성 된 domdocument 객체와 함께 XPath를 사용할 수 있습니다.

PHP dom에서 xpath를 사용할 때 오류를 처리하는 방법은 무엇입니까? loadHTML() PHP DOM에서 XPath를 사용하는 경우, 잘못된 XPATH 표현식 형식 또는 XML 문서와 같은 여러 가지 이유로 오류가 발생할 수 있습니다. 이러한 오류를 처리하려면 함수를 사용하여 사용자 오류 처리를 활성화 할 수 있습니다. 이 기능으로 인해 libxml 오류가 내부적으로 저장되어 코드에서 처리 할 수 ​​있습니다. 그런 다음 함수를 사용하여 오류를 검색하고 필요에 따라 처리 할 수 ​​있습니다.

PHP dom에서 xpath를 사용하여 XML 문서를 수정할 수 있습니까?

XPath 자체는 XML 문서를 수정하는 방법을 제공하지 않지만 DOM API와 함께 XPath를 사용하여 XML 문서를 수정할 수 있습니다. XPath를 사용하여 수정하려는 노드를 선택한 다음 DOM API에서 제공 한 메소드를 사용하여 수정할 수 있습니다. 예를 들어, domnode 클래스의

메소드를 사용하여 노드를 삭제하거나 Domlement 클래스의

메소드를 사용하여 속성 값을 변경할 수 있습니다. libxml_use_internal_errors()

위 내용은 PHP DOM : XPath 사용의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
PHP와 Python : 다른 패러다임이 설명되었습니다PHP와 Python : 다른 패러다임이 설명되었습니다Apr 18, 2025 am 12:26 AM

PHP는 주로 절차 적 프로그래밍이지만 객체 지향 프로그래밍 (OOP)도 지원합니다. Python은 OOP, 기능 및 절차 프로그래밍을 포함한 다양한 패러다임을 지원합니다. PHP는 웹 개발에 적합하며 Python은 데이터 분석 및 기계 학습과 같은 다양한 응용 프로그램에 적합합니다.

PHP와 Python : 그들의 역사에 깊은 다이빙PHP와 Python : 그들의 역사에 깊은 다이빙Apr 18, 2025 am 12:25 AM

PHP는 1994 년에 시작되었으며 Rasmuslerdorf에 의해 개발되었습니다. 원래 웹 사이트 방문자를 추적하는 데 사용되었으며 점차 서버 측 스크립팅 언어로 진화했으며 웹 개발에 널리 사용되었습니다. Python은 1980 년대 후반 Guidovan Rossum에 의해 개발되었으며 1991 년에 처음 출시되었습니다. 코드 가독성과 단순성을 강조하며 과학 컴퓨팅, 데이터 분석 및 기타 분야에 적합합니다.

PHP와 Python 중에서 선택 : 가이드PHP와 Python 중에서 선택 : 가이드Apr 18, 2025 am 12:24 AM

PHP는 웹 개발 및 빠른 프로토 타이핑에 적합하며 Python은 데이터 과학 및 기계 학습에 적합합니다. 1.PHP는 간단한 구문과 함께 동적 웹 개발에 사용되며 빠른 개발에 적합합니다. 2. Python은 간결한 구문을 가지고 있으며 여러 분야에 적합하며 강력한 라이브러리 생태계가 있습니다.

PHP 및 프레임 워크 : 언어 현대화PHP 및 프레임 워크 : 언어 현대화Apr 18, 2025 am 12:14 AM

PHP는 현대화 프로세스에서 많은 웹 사이트 및 응용 프로그램을 지원하고 프레임 워크를 통해 개발 요구에 적응하기 때문에 여전히 중요합니다. 1.PHP7은 성능을 향상시키고 새로운 기능을 소개합니다. 2. Laravel, Symfony 및 Codeigniter와 같은 현대 프레임 워크는 개발을 단순화하고 코드 품질을 향상시킵니다. 3. 성능 최적화 및 모범 사례는 응용 프로그램 효율성을 더욱 향상시킵니다.

PHP의 영향 : 웹 개발 및 그 이상PHP의 영향 : 웹 개발 및 그 이상Apr 18, 2025 am 12:10 AM

phphassignificallyimpactedwebdevelopmentandextendsbeyondit

스칼라 유형, 반환 유형, 노조 유형 및 무효 유형을 포함한 PHP 유형의 힌트 작업은 어떻게 작동합니까?스칼라 유형, 반환 유형, 노조 유형 및 무효 유형을 포함한 PHP 유형의 힌트 작업은 어떻게 작동합니까?Apr 17, 2025 am 12:25 AM

PHP 유형은 코드 품질과 가독성을 향상시키기위한 프롬프트입니다. 1) 스칼라 유형 팁 : PHP7.0이므로 int, float 등과 같은 기능 매개 변수에 기본 데이터 유형을 지정할 수 있습니다. 2) 반환 유형 프롬프트 : 기능 반환 값 유형의 일관성을 확인하십시오. 3) Union 유형 프롬프트 : PHP8.0이므로 기능 매개 변수 또는 반환 값에 여러 유형을 지정할 수 있습니다. 4) Nullable 유형 프롬프트 : NULL 값을 포함하고 널 값을 반환 할 수있는 기능을 포함 할 수 있습니다.

PHP는 객체 클로닝 (클론 키워드) 및 __clone 마법 방법을 어떻게 처리합니까?PHP는 객체 클로닝 (클론 키워드) 및 __clone 마법 방법을 어떻게 처리합니까?Apr 17, 2025 am 12:24 AM

PHP에서는 클론 키워드를 사용하여 객체 사본을 만들고 \ _ \ _ Clone Magic 메소드를 통해 클로닝 동작을 사용자 정의하십시오. 1. 복제 키워드를 사용하여 얕은 사본을 만들어 객체의 속성을 복제하지만 객체의 속성은 아닙니다. 2. \ _ \ _ 클론 방법은 얕은 복사 문제를 피하기 위해 중첩 된 물체를 깊이 복사 할 수 있습니다. 3. 복제의 순환 참조 및 성능 문제를 피하고 클로닝 작업을 최적화하여 효율성을 향상시키기 위해주의를 기울이십시오.

PHP vs. Python : 사용 사례 및 응용 프로그램PHP vs. Python : 사용 사례 및 응용 프로그램Apr 17, 2025 am 12:23 AM

PHP는 웹 개발 및 컨텐츠 관리 시스템에 적합하며 Python은 데이터 과학, 기계 학습 및 자동화 스크립트에 적합합니다. 1.PHP는 빠르고 확장 가능한 웹 사이트 및 응용 프로그램을 구축하는 데 잘 작동하며 WordPress와 같은 CMS에서 일반적으로 사용됩니다. 2. Python은 Numpy 및 Tensorflow와 같은 풍부한 라이브러리를 통해 데이터 과학 및 기계 학습 분야에서 뛰어난 공연을했습니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

Atom Editor Mac 버전 다운로드

Atom Editor Mac 버전 다운로드

가장 인기 있는 오픈 소스 편집기

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.