리자

링크를 세부분으로 나누어 추출하려고 합니다.

html 코드내에서,
링크를 세부분으로 나누어 추출하려고 합니다.
다음과 같은 html 내용이 있을때,
**************************************************************
<a target=_blank href='http://www.naver.com'>네이버</a>
<area shape="RECT" target="_blank" coords="10,10,135,60" href="http://www.daum.net" />
**************************************************************

1. <a 혹은 <area 태그 내용
(예: <a target=_blank href='http://www.naver.com'> )
2. 1내용중 href의 내용
(href내용은 큰따옴표 혹은 작은따옴표로 감싸지거나 그냥 링크만 있을수도..)
3. <a 혹은 <area 의 텍스트내용
(위 html의 첫째줄에서는 네이버, 둘째줄에서는 공백이 되겠네요.)

이 세 내용을 preg_match_all 함수와 정규식을 이용해 추출하고자 하는데,
정규식 작성이 잘 되지 않네요..

고수님들의 조언 부탁드립니다.<div class='small'>[이 게시물은 관리자님에 의해 2011-10-31 17:16:08 PHP & HTML에서 이동 됨]</div>
|

댓글 2개

내공이 부족해서 preg_match_all 은 못하겠네요.

<?
$s =<<<HTMLCODE
<a target=_blank href='http://www.naver.com'>네이버</a>
<area shape="RECT" target="_blank" coords="10,10,135,60" href="http://www.daum.net" />
HTMLCODE;

preg_match("/(\<a[^\>]*\>)/i", $s, $match1);
preg_match("/href\=[\"\']?([^\"\'\s\>]+)/i", $match1[1], $match2);
preg_match("/\<a[^\>]*\>(.*)\<\/a/i", $s, $match3);
?>
<textarea rows=10 cols=100><?print_r($match1)?></textarea>
<textarea rows=10 cols=100><?print_r($match2)?></textarea>
<textarea rows=10 cols=100><?print_r($match3)?></textarea>
preg_match_all 로 만들어 봤습니다.

preg_match_all("/(<a[^>]*href=[\"']?([^>\"'\s]+)[\"']?[^>]*>)([^<]*)/i", $s, $out1);

echo "<xmp>";
print_r($out1);
echo "</xmp>";

Array
(
[0] => Array
(
[0] => <a target=_blank href='http://www.naver.com'>네이버
[1] => <area shape="RECT" target="_blank" coords="10,10,135,60" href="http://www.daum.net" />
)

[1] => Array
(
[0] => <a target=_blank href='http://www.naver.com'>
[1] => <area shape="RECT" target="_blank" coords="10,10,135,60" href="http://www.daum.net" />
)

[2] => Array
(
[0] => http://www.naver.com
[1] => http://www.daum.net
)

[3] => Array
(
[0] => 네이버
[1] =>
)

)
댓글을 작성하시려면 로그인이 필요합니다.

프로그램

+
제목 글쓴이 날짜 조회
15년 전 조회 2,114
15년 전 조회 2,483
15년 전 조회 1,906
15년 전 조회 8,098
15년 전 조회 1,519
15년 전 조회 1,749
15년 전 조회 1,464
15년 전 조회 1,700
15년 전 조회 1,460
15년 전 조회 1,682
15년 전 조회 1,399
15년 전 조회 2,499
15년 전 조회 1,512
15년 전 조회 1,397
15년 전 조회 1,914
15년 전 조회 1,790
15년 전 조회 1,511
15년 전 조회 1,394
15년 전 조회 1,421
15년 전 조회 1,700
15년 전 조회 1,284
15년 전 조회 1,379
15년 전 조회 1,574
15년 전 조회 2,272
15년 전 조회 1,521
15년 전 조회 1,608
15년 전 조회 1,373
15년 전 조회 1,330
15년 전 조회 1,688
15년 전 조회 2,126
15년 전 조회 1,414
15년 전 조회 1,752
15년 전 조회 2,018
15년 전 조회 1,392
15년 전 조회 1,318
15년 전 조회 1,471
15년 전 조회 1,532
15년 전 조회 1,321
15년 전 조회 1,612
15년 전 조회 1,709
15년 전 조회 1,617
15년 전 조회 3,540
15년 전 조회 1,197
15년 전 조회 1,776
15년 전 조회 1,328
15년 전 조회 2,157
15년 전 조회 1,132
15년 전 조회 1,266
15년 전 조회 1,263
15년 전 조회 1,295
15년 전 조회 2,015
15년 전 조회 3,335
15년 전 조회 2,403
15년 전 조회 2,314
15년 전 조회 1,300
15년 전 조회 1,401
15년 전 조회 1,336
15년 전 조회 1,230
15년 전 조회 1,529
15년 전 조회 1,226
15년 전 조회 1,688
15년 전 조회 1,115
15년 전 조회 1,013
15년 전 조회 1,900
15년 전 조회 1,162
15년 전 조회 1,606
15년 전 조회 1,472
15년 전 조회 1,155
15년 전 조회 1,176
15년 전 조회 1,096
15년 전 조회 1,055
15년 전 조회 1,246
15년 전 조회 1,482
15년 전 조회 2,672
15년 전 조회 1,266
15년 전 조회 1,359
15년 전 조회 1,384
15년 전 조회 1,391
15년 전 조회 1,441
15년 전 조회 1,057
15년 전 조회 2,337
15년 전 조회 1,181
15년 전 조회 1,971
15년 전 조회 1,108
15년 전 조회 1,134
15년 전 조회 1,795
15년 전 조회 1,398
15년 전 조회 1,716
15년 전 조회 2,019
15년 전 조회 1,637
15년 전 조회 1,735
15년 전 조회 1,118
15년 전 조회 2,650
15년 전 조회 1,389
15년 전 조회 1,116
15년 전 조회 1,469
15년 전 조회 1,169
15년 전 조회 2,451
15년 전 조회 1,464
15년 전 조회 1,293