XPath는 기능을 작성하는 더 간단하고 깨끗한 방법을 제공하고 쿼리를 작성하고 XML 데이터를 필터하는 데 필요한 코드의 양을 줄이는 XML 문서를 쿼리하기위한 구문입니다.
- 를 반환하는 결과 유형의 유형을 반환하는 반면, 는 가능한 한 입력 된 결과를 반환한다는 것입니다.
-
XPath를 사용하면 코드를보다 간결하고 효율적으로 만들 수 있습니다. 비교 테스트에서 XPATH 버전은 비 XPATH 버전보다 약 10% 빠른 Pure XPath를 사용하는 속도 이점이 매우 분명합니다.
query()
PHP DOM을 사용하면 사용자 정의 함수로 표준 XPATH 기능을 확장 할 수 있습니다. 여기에는 PHP 자체 기능을 XPath 쿼리에 통합하고 XPath에 사용되는 PHP 기능 등록이 포함됩니다. 이것은 XPath의 기능을 확장하여보다 복잡한 쿼리를 수행 할 수 있도록합니다.evaluate()
query()
이 기사는 기능과 PHP에서 어떻게 구현되는지를 포함하여 XPath를 깊이 탐색 할 것입니다. XPath는 쿼리를 작성하고 XML 데이터를 필터링하는 데 필요한 코드의 양을 크게 줄이고 일반적으로 성능을 향상시킬 수 있습니다. 이전 게시물에서 동일한 DTD 및 XML을 사용하여 PHP DOM XPATH 기능을 보여 드리겠습니다. 빠른 검토를 위해 DTD와 XML은 다음과 같습니다.DOMNodeList
evaluate()
기본 xpath 쿼리
XPath는 XML 문서를 쿼리하기위한 구문입니다. 가장 간단한 형태는 액세스하려는 요소의 경로를 정의하는 것입니다. 위의 XML 문서를 사용하면 다음 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)> ]>는 가능한 한 입력 된 결과를 반환합니다. 예를 들어, 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 에서 PHP 함수를 사용하는
를 xpath 쿼리에 직접 통합 할 수도 있습니다. 이를 위해서는 여러 단계를 완료해야합니다. 먼저 XPath 객체를 사용하여 네임 스페이스를 등록해야합니다. XPath 쿼리의 PHP 함수는 ""로 시작하여 사용하려는 기능의 이름을 괄호로 둘러싸고 있습니다. 또한, 정의 할 네임 스페이스는
메소드를 만들 수 있습니다
를 필요에 따라 필요로하는 것입니다. . (Fotolia의 그림)
XPATH 를 가진 php dom에 대한 faqs (FAQ)
xpath 쿼리에서 네임 스페이스를 처리하려면 메소드를 사용하여 DomxPath 객체와 네임 스페이스를 등록해야합니다. 이 방법에는 접두사와 네임 스페이스 URI의 두 가지 매개 변수가 있습니다. 네임 스페이스를 등록한 후 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)>
]>
<?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>
count()
가 반환되지만 빈 목록이라는 것을 알 수 있습니다. 이것은 코드를 더 간결하게 만들뿐만 아니라 속도의 장점도 있습니다. 버전 1은 버전 2보다 평균 속도가 30% 더 빠르지 만 버전 3은 버전 2보다 약 10% 빠릅니다 (버전 1보다 약 15% 더 빠릅니다). 이러한 측정은 서버와 쿼리에 따라 다르지만 순수한 XPath를 사용하면 상당한 속도 이점을 가져 오는 동시에 코드를 쉽게 읽고 유지 관리 할 수 있습니다. //library/book
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)>
]>
그러나 str_word_count()
입니다. 네임 스페이스는 다른 값으로 설정해야합니다. 그런 다음 PHP에게 "php:functionString
http://php.net/xpath
: 의 다음과 같은 상환을 받으십시오.
registerPHPFunctions()
php:
메소드가 자동으로 수행합니다. 그러나 다음은 유효합니다
<?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"]/..
php:function
요약 php:functionString
true
XPath는 XML 데이터를 처리 할 때 코드 작성 및 코드 실행 속도를 높이는 좋은 방법입니다. 공식 DOM 사양의 일부는 아니지만 PHP DOM이 제공하는 추가 기능을 사용하면 사용자 지정 기능으로 표준 XPATH 기능을 확장 할 수 있습니다. 이것은 매우 강력한 기능이며 XPath 기능에 더 익숙해지면서 자신이 점점 더 적게 의존 할 수 있습니다. 메소드는 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를 반환합니다. 반면에
는 domnodelist를 반환합니다. query()
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>
<book></book>
<title></title>
요소를 선택하려면 다음과 같이
메소드를 사용하여 HTML 문서를로드 할 수 있습니다. 이 메소드는 HTML을 구문 분석하고 형식화 오류를 수정하여 생성 된 domdocument 객체와 함께 XPath를 사용할 수 있습니다. loadHTML()
메소드를 사용하여 노드를 삭제하거나 Domlement 클래스의 libxml_use_internal_errors()
위 내용은 PHP DOM : XPath 사용의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

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

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

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

phphassignificallyimpactedwebdevelopmentandextendsbeyondit

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

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

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


핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기

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

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

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

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