QueryList Recursive Collection 결과 예외 : 왜 문서 예제가 실제 결과와 일치하지 않는가?
QueryList Recursive Collection : 예상 결과와 실제 결과 및 솔루션의 차이 분석
다단계 데이터 크롤링에 QueryList를 사용할 때 개발자는 종종 문서 예제가 실제 실행 결과와 일치하지 않는 상황을 만나는 경우가 종종 있습니다. 이 기사는 사례를 사용하여 문제의 근본 원인을 깊이 분석하고 효과적인 솔루션을 제공합니다.
문제 설명 :
목표는 HTML 구조에서 제목과 정보를 추출하는 것입니다. HTML 구조는 다음과 같습니다.
<div id="demo"> <ul> <li> <h3 id="트리플-엑스">트리플 엑스</h3> <div class="list"> <div class="item">항목 1</div> <div class="item">항목 2</div> </div> </li> <li> <h3 id="xxx">xxx2</h3> <div class="list"> <div class="item">item12</div> <div class="item">item22</div> </div> </li> </ul> </div>
데이터 추출을 위해 QueryList 코드를 사용하십시오.
// ... (코드 스 니펫이 누락되어 완전히 분석 할 수 없습니다) ...
예상 결과는 각각을 추출하는 것입니다<li>
다음<h3></h3>
제목 및 item
내용. 그러나 실제 결과는 item
내용의 합병입니다.
<code>Array ( [0] => Array ( [title] => xxx [list] => Array ( [item] => item1item2 ) ) [1] => Array ( [title] => xxx2 [list] => Array ( [item] => item12item22 ) ) )</code>
문제 분석 :
문제는 내부 QueryList 객체가 외부 QueryList 객체의 range
매개 변수를 상속한다는 것입니다. range('')
실제로 선택기를 재설정하지 않아 외부 range('#demo li')
의 선택기를 사용하여 item
컨텐츠 병합을 만듭니다. 이는 쿼리리스트 내부 메커니즘 또는 코드의 기타 문제 때문일 수 있습니다. range('')
항상 범위를 올바르게 재설정하는 것은 아니며보다 심층 분석이 필요합니다.
해결책:
이 문제를 해결하려면 내부 쿼리리스트 객체가 외부 객체와 독립적으로 작동하도록해야합니다. 간단한 range('')
작동하지 않을 수 있으므로보다 신뢰할 수있는 방법이 필요합니다. 다음 솔루션을 시도 할 수 있습니다.
- <li> 보다 정확한 선택기 사용 :
range()
사용하지 않고보다 정확한 CSS 선택기를 rules
으로 직접 사용하십시오.$ data = querylist :: html ($ html) -> 규칙 ([[ 'title'=> [ 'h3', 'text'], 'list'=> [ '.list .item', 'text'] // 모든 .item 요소를 직접 선택])). -> 범위 ( '#demo li') -> query (); // Query ()가 바로 여기에서 사용되며 QueryData ()의 재귀 덤프 ($ data)가 더 이상 필요하지 않습니다.
이 메소드는 재귀로 인한 문제를 피하면서 모든 .item
요소의 텍스트 내용을 직접 추출합니다.
- <li> 수동 루프 처리 : QueryList의 재귀 기능을 포기하고 각각 수동으로 루프 처리
<li> 요소:
$ lis = queryList :: html ($ html)-> find ( '#demo li'); $ data = []; foreach ($ lis as $ li) { $ item = []; $ item [ 'title'] = queryList :: html ($ li)-> find ( 'h3')-> text (); $ items = QueryList :: html ($ li)-> find ( '. list .item')-> map (function ($ item) {return $ item-> text ();})-> all (); $ item [ 'list'] = $ 항목; $ data [] = $ 항목; } 덤프 ($ data);
이 방법은 더 명확하고 이해하고 디버그하기 쉽습니다.
- <li> QueryList 소스 코드 및 문서에 대한 심층 조사 : 위의 방법이 유효하지 않은 경우 QueryList 소스 코드 및 문서에 대한 심층적 인 연구를 수행해야하며,
range()
메소드의 특정 동작 및 잠재적 문제를 찾아 QueryList가 제공 한 다른 기능을 시도 하여이 문제를 해결해야합니다. QueryList 버전 및 PHP 버전 호환성을 확인해야 할 수도 있습니다.선택할 옵션은 특정 요구 사항과 QueryList에 대한 친숙성에 따라 다릅니다. 간단하고 효율적이기 때문에 방법 1에 우선 순위를 부여하는 것이 좋습니다. 방법 1이 요구 사항을 충족 할 수없는 경우 방법 2를 다시 고려하십시오. 방법 3은 마지막 선택이며보다 심층적 인 프로그래밍 지식이 필요합니다. QueryList의 공식 문서 및 샘플 코드를 항상 확인하여 기능을 올바르게 사용하는지 확인하십시오.
위 내용은 QueryList Recursive Collection 결과 예외 : 왜 문서 예제가 실제 결과와 일치하지 않는가?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

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

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

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

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

vue.js에서 bootstrap 사용은 5 단계로 나뉩니다 : Bootstrap 설치. main.js.의 부트 스트랩 가져 오기 부트 스트랩 구성 요소를 템플릿에서 직접 사용하십시오. 선택 사항 : 사용자 정의 스타일. 선택 사항 : 플러그인을 사용하십시오.

WebDevelopmentReliesonHtml, CSS 및 JavaScript : 1) HtmlStructuresContent, 2) CSSSTYLESIT, 및 3) JAVASCRIPTADDSINGINTERACTIVITY, BASISOFMODERNWEBEXPERIENCES를 형성합니다.

HTML은 웹 구조를 정의하고 CSS는 스타일과 레이아웃을 담당하며 JavaScript는 동적 상호 작용을 제공합니다. 세 사람은 웹 개발에서 의무를 수행하고 화려한 웹 사이트를 공동으로 구축합니다.

Bootstrap에 이미지를 삽입하는 방법에는 여러 가지가 있습니다. HTML IMG 태그를 사용하여 이미지를 직접 삽입하십시오. 부트 스트랩 이미지 구성 요소를 사용하면 반응 형 이미지와 더 많은 스타일을 제공 할 수 있습니다. 이미지 크기를 설정하고 IMG-Fluid 클래스를 사용하여 이미지를 적응할 수 있도록하십시오. IMG 통과 클래스를 사용하여 테두리를 설정하십시오. 둥근 모서리를 설정하고 IMG 라운드 클래스를 사용하십시오. 그림자를 설정하고 그림자 클래스를 사용하십시오. CSS 스타일을 사용하여 이미지를 조정하고 배치하십시오. 배경 이미지를 사용하여 배경 이미지 CSS 속성을 사용하십시오.

부트 스트랩 분할 라인을 만드는 두 가지 방법이 있습니다 : 태그를 사용하여 수평 분할 라인이 생성됩니다. CSS 테두리 속성을 사용하여 사용자 정의 스타일 분할 라인을 만듭니다.

부트 스트랩 프레임 워크를 설정하려면 다음 단계를 따라야합니다. 1. CDN을 통해 부트 스트랩 파일 참조; 2. 자신의 서버에서 파일을 다운로드하여 호스팅하십시오. 3. HTML에 부트 스트랩 파일을 포함; 4. 필요에 따라 Sass/Less를 컴파일하십시오. 5. 사용자 정의 파일을 가져옵니다 (선택 사항). 설정이 완료되면 Bootstrap의 그리드 시스템, 구성 요소 및 스타일을 사용하여 반응 형 웹 사이트 및 응용 프로그램을 만들 수 있습니다.

부트 스트랩 버튼을 사용하는 방법? 부트 스트랩 CSS를 소개하여 버튼 요소를 만들고 부트 스트랩 버튼 클래스를 추가하여 버튼 텍스트를 추가하십시오.
