用phpQuery像jquery一样解析html代码,phpqueryjquery
简介
如何在php中方便地解析html代码,估计是每个phper都会遇到的问题。用phpQuery就可以让php处理html代码像jQuery一样方便。
项目地址:https://code.google.com/p/phpquery/
github地址:https://github.com/TobiaszCudnik/phpquery
DEMO
下载库文件:https://code.google.com/p/phpquery/downloads/list
我下的是onefile版:phpQuery-0.9.5.386-onefile.zip
官方demo:https://code.google.com/p/phpquery/source/browse/branches/dev/demo.php
然后在项目中引用。
html文件test.html:
<span><</span><span>div </span><span>class</span><span>="thumb"</span><span> id</span><span>="Thumb-13164-3640"</span><span> style</span><span>="position: absolute; left: 0px; top: 0px;"</span><span>></span> <span><</span><span>a </span><span>href</span><span>="/Spiderman-City-Drive"</span><span>></span> <span><</span><span>img </span><span>src</span><span>="/thumb/12/Spiderman-City-Drive.jpg"</span><span> alt</span><span>=""</span><span>></span> <span><</span><span>span </span><span>class</span><span>="GameName"</span><span> id</span><span>="GameName-13164-3640"</span><span> style</span><span>="display: none;"</span><span>></span>Spiderman City Drive<span></</span><span>span</span><span>></span> <span><</span><span>span </span><span>class</span><span>="GameRating"</span><span> id</span><span>="GameRating-13164-3640"</span><span> style</span><span>="display: none;"</span><span>></span> <span><</span><span>span </span><span>style</span><span>="width: 68.14816px;"</span><span>></</span><span>span</span><span>></span> <span></</span><span>span</span><span>></span> <span></</span><span>a</span><span>></span> <span></</span><span>div</span><span>></span> <span><</span><span>div </span><span>class</span><span>="thumb"</span><span> id</span><span>="Thumb-13169-5946"</span><span> style</span><span>="position: absolute; left: 190px; top: 0px;"</span><span>></span> <span><</span><span>a </span><span>href</span><span>="/Spiderman-City-Raid"</span><span>></span> <span><</span><span>img </span><span>src</span><span>="/thumb/12/Spiderman-City-Raid.jpg"</span><span> alt</span><span>=""</span><span>></span> <span><</span><span>span </span><span>class</span><span>="GameName"</span><span> id</span><span>="GameName-13169-5946"</span><span> style</span><span>="display: none;"</span><span>></span>Spiderman - City Raid<span></</span><span>span</span><span>></span> <span><</span><span>span </span><span>class</span><span>="GameRating"</span><span> id</span><span>="GameRating-13169-5946"</span><span> style</span><span>="display: none;"</span><span>></span> <span><</span><span>span </span><span>style</span><span>="width: 67.01152px;"</span><span>></</span><span>span</span><span>></span> <span></</span><span>span</span><span>></span> <span></</span><span>a</span><span>></span> <span></</span><span>div</span><span>></span>
php处理:
<?<span>php </span><span>include</span>('phpQuery-onefile.php'<span>); </span><span>$filePath</span> = 'test.html'<span>; </span><span>$fileContent</span> = <span>file_get_contents</span>(<span>$filePath</span><span>); </span><span>$doc</span> = phpQuery::newDocumentHTML(<span>$fileContent</span><span>); phpQuery</span>::selectDocument(<span>$doc</span><span>); </span><span>$data</span> = <span>array</span><span>( </span>'name' => <span>array</span>(), 'href' => <span>array</span>(), 'img' => <span>array</span><span>() ); </span><span>foreach</span> (pq('a') <span>as</span> <span>$t</span><span>) { </span><span>$href</span> = <span>$t</span> -> getAttribute('href'<span>); </span><span>$data</span>['href'][] = <span>$href</span><span>; } </span><span>foreach</span> (pq('img') <span>as</span> <span>$img</span><span>) { </span><span>$data</span>['img'][] = <span>$domain</span> . <span>$img</span> -> getAttribute('src'<span>); } </span><span>foreach</span> (pq('.GameName') <span>as</span> <span>$name</span><span>) { </span><span>$data</span>['name'][] = <span>$name</span> -><span> nodeValue; } </span><span>var_dump</span>(<span>$data</span><span>); </span>?>
上面的代码中包含了取属性和innerText内容(通过nodeValue取)。
输出:
<span>array</span> (size=3<span>) </span>'name' => <span>array</span> (size=2<span>) </span>0 => <span>string</span> 'Spiderman City Drive' (length=20<span>) </span>1 => <span>string</span> 'Spiderman - City Raid' (length=21<span>) </span>'href' => <span>array</span> (size=2<span>) </span>0 => <span>string</span> 'http://www.gahe.com/Spiderman-City-Drive' (length=40<span>) </span>1 => <span>string</span> 'http://www.gahe.com/Spiderman-City-Raid' (length=39<span>) </span>'img' => <span>array</span> (size=2<span>) </span>0 => <span>string</span> 'http://www.gahe.com/thumb/12/Spiderman-City-Drive.jpg' (length=53<span>) </span>1 => <span>string</span> 'http://www.gahe.com/thumb/12/Spiderman-City-Raid.jpg' (length=52)
强大的是pq选择器,语法类似jQuery,很方便。

핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

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

SecList
SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

PhpStorm 맥 버전
최신(2018.2.1) 전문 PHP 통합 개발 도구

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

ZendStudio 13.5.1 맥
강력한 PHP 통합 개발 환경
