테스트 사이트 - 개발 중인 베타 버전입니다
게시판에 써진 글내용(테그포함) 에서 파일링크 부분만을 추출하려고 하고 있습니다.

정규식을 이용하여 split 로 처리하면 될줄 알았는데..

문자열을 비교해서 배열로 저장하니, 제가 원한것이 아닌 반대것이 추출되네요..

함수를 잘못사용한것 맞습니다... split 함수의 내용은 알고 있습니다.

제가 원하는 함수나 정규식이 있는지 궁금합니다.

예시
글내용 )
내용~~~~<IMG src="http://aaa/uploaded/111.jpg"border=0>내용~~테그~~~<IMG src="http://aaa/uploaded/222.jpg"border=0>~~~~~~내용

위와 같을때 제가 추출을 원하는 값은

http://aaa/uploaded/111.jpg
http://aaa/uploaded/222.jpg

입니다.

중요한것은 위와 같을때, http://aaa/uploaded/111.jpg 식의 정규식은 만들수 있는데요..

$b=split("(http://aaa/uploaded/)([[:alnum:]]){3}\.([[:alnum:]]){3}",$a);

이것으로 split 하면, 당연히~~~ 원하지 않는 값들로 분리가 된다는점입니다.

만든 정규식에 반대 개념을 적용하면 될것 같은데..

그런 정규식은 못찾겠어요..

조언 부탁드립니다.
[이 게시물은 관리자님에 의해 2011-10-31 17:16:08 PHP & HTML에서 이동 됨]

댓글 작성

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

로그인하기

댓글 3개

$s = "...문자열...";
$s = preg_match_all("/<img\s+.*?src=[\"\']([^\"\']+)[\"\'\s][^>]*>/is", $s, $m);
print_r($m);
http://phpschool.com/gnuboard4/bbs/board.php?bo_table=qna_function&wr_id=227938&sca=&sfl=mb_id&stx=kagla&sop=and
<?php

$text = <<<TEXT
내용~~~~<IMG src="http://aaa/uploaded/111.jpg" border=0>내용~~테그~~~<IMG src="http://aaa/uploaded/222.jpg" border=0>~~~~~~내용
TEXT;

preg_match_all("`<img [^>]*src\s*=\s*([^>\s]+)`i", $text, $match);


if (is_array($match[1])) {

foreach($match[1] as $k => $v){

$temp[$k] = trim(str_replace(array("'", '"'), '', $v));
}
}

print_r($temp);
?>

게시판 목록

프로그램

글쓰기