메뉴 건너뛰기

프로그램언어

조회 수 4091 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

글 속에서 링크만을 추출하고

추출한 링크 속에서 어떤 패턴 여러 경우를 골라내려고 합니다.

예를 들어 링크된 파일의 종류, 링크 속의 속성 (title, class, onmouseover등등)이 내가 원하는 것들과 매치가 되는지 검색을 하고 매치가 되거나 안 되거나만 가려내려고 합니다.

 

이때 eregi가 빠를까요. strpos가 빠를까요?

 if (eregi('','')) {} 
if (strpos('','') !== false) {}
검색어와 매치를 시킬 때 1번이 빠른가요 2번이 빠른가요?

 $cut_data[0] = '.png';
 $cut_data[1] = '.gif';
 $cut_data[2] = '.jpg';   for($i=0; $i < $for_cnt; $i++) {} 
$anchor_rel = array('.png','.gif','.jpg');   foreach ($anchor_rel as $example) {}
아니면 더 효율적인 방법이 있을까요?

 

---------------------------------------------------------------------------------------

 

 

strpos가 더빠릅니다.


eregi같은경우에는. 느리기로 소문난 함수중에 하나입니다.(ereg_replace,ereg같은함수 )

$str ="124999aggg";

if(eregi("[0-9]",$str))

이와 같이 정규식을 쓸수 있기에.. 정규표현식을 패턴을 검사하가위해..

당연히 단순히 문자를 검색하는 strpos보다 더느릴수 밖에없읍니다.


두번째질문은 밑에 테스트한결과로 보여드리겠습니다

for($j = 0 ; $j <5 ; $j++)
{

$arr = range(1,10000000);
$time =getmicrotime();
$cnt = sizeof($arr);
for($i =0 ; $i < $cnt ; $i++){}
print getmicrotime()-$time;
print " : for";
print "\n";
print "\n";
$time =getmicrotime();
foreach($arr as $v){}
print getmicrotime()-$time;
print " : foreach";
print "\n";
print "\n";
}
function getmicrotime()
{
list($usec, $sec) = explode(" ", microtime());
return ((float)$usec + (float)$sec);
}
결과는


2.57946896553 : for

9.61373019218 : foreach

2.59991693497 : for

21.459086895 : foreach

2.67453289032 : for

12.387665987 : foreach

2.61338496208 : for

10.5894870758 : foreach

2.70486783981 : for

10.1344602108 : foreach
입니다.

위의 속도 계산을 보셧듯이..

for가 아무래도.속도는 더 빠릅니다.

하지만 foreach의 확장성이나 특성을.. 개인적으로 더좋아하기에 ..

foreach를 추천하고싶군요..


더낳은 방법이라면.. 데이타에서. 하나하나 찾는거보다. 전체를 한꺼번에

찾는 방법이 있긴합니다. 아주유용한 함수가 있습니다.

preg_match_all 함수가 있습니다.

글에서.. 정규식에 맞는 글자들을 전역적으로 뽑아서 변수에 저장시켜줍니다.

사용예입니다.

$url = "http://test.com";
$text=@file_get_contents($url);
if ($text)
{
$src_href_url=run_preg($text,
"/(?:(?:src|href|url)\\s*[=\\(]\\s*[\\"'`])".
"([\\+\\w:?=@&\\/#._;-]+)(?:[\\s\\"'`])/i");
$windows=run_preg($text,
"/(?:window.open\\s*\\(\\s*[\\w-]*\\s*[,]\\s*[\\"`'])".
"([\\+\\w:?=@&\\/#._;-]*)(?:[\\"'`]\\s*)/i");
}

function run_preg($text,$pattern) {

preg_match_all ($pattern, $text, $matches);

if (count($matches)>0)
if (count($matches[1])>0)
foreach ($matches[1] as $k => $v)
echo "$k: $v\\n";

return (is_array($matches)) ? $matches[1]:FALSE;
}

 


  1. PHP eregi가 빠를까, strpos가 빠를까?

    Date2018.10.27 Views4091
    Read More
  2. php date 날짜 관련 함수

    Date2021.03.27 Views411
    Read More
  3. PHP continue 문

    Date2015.04.14 Views21097
    Read More
  4. PHP - 공공 DATA XML 파싱(PHP 버전)

    Date2023.01.12 Views270
    Read More
  5. PHP + 유튜브(youtube) 동영상 업로드 연동 소스

    Date2021.01.21 Views1141
    Read More
  6. PHP $_SERVER 함수

    Date2019.02.25 Views1558
    Read More
  7. PEAR DB 관련 함수들

    Date2021.03.26 Views690
    Read More
  8. parse_ini_file — Parse a configuration file

    Date2016.12.23 Views19774
    Read More
  9. MySQL테이블의 내용을 엑셀파일(xls)로 다운로드 하기

    Date2018.07.24 Views4798
    Read More
  10. mysql_result — 결과 데이터를 반환

    Date2016.12.23 Views18967
    Read More
  11. mysql_real_escape_string 이진 데이터를 입력할 경우 이 함수를 사용해야 함

    Date2016.12.23 Views18640
    Read More
  12. mysql_insert_id

    Date2016.12.23 Views18750
    Read More
  13. mysql_free_result(); 관련 오류

    Date2021.03.25 Views340
    Read More
  14. mysql_affected_rows — 최근 MySQL 작업으로 변경된 행 개수를 얻음

    Date2016.12.23 Views18807
    Read More
  15. MySQL(MariaDB) 테이블 만들기

    Date2018.03.28 Views8154
    Read More
  16. mysql 에러 구문 표시

    Date2014.02.27 Views20349
    Read More
  17. MYSQL 업데이트 두 번 하기

    Date2014.02.27 Views19729
    Read More
  18. MYSQL DB의 모든 테이블에서 문자열 검색 하기

    Date2021.03.26 Views915
    Read More
  19. MySQL DB 중복여부 검사하여 없는 것만 추가

    Date2015.04.14 Views20157
    Read More
  20. MYSQL DB 다중접속을 해결 하는 한 방법

    Date2021.03.26 Views284
    Read More
Board Pagination Prev 1 ... 8 9 10 11 12 13 14 15 16 17 Next
/ 17

하단 정보를 입력할 수 있습니다

© k2s0o1d4e0s2i1g5n. All Rights Reserved