sql >> Database teknologi >  >> RDS >> Mysql

Hvordan genererer man kodestykket som dem, der er genereret af Google med PHP og MySQL?

Ændrede decezes funktion lidt for at tillade flere sætninger. for eksempel. din sætning kan være "testa testb", og hvis den ikke finder testa, vil den gå til testb.

function excerpt($text, $phrase, $radius = 100, $ending = "...") { 


         $phraseLen = strlen($phrase); 
       if ($radius < $phraseLen) { 
             $radius = $phraseLen; 
         } 

         $phrases = explode (' ',$phrase);

         foreach ($phrases as $phrase) {
             $pos = strpos(strtolower($text), strtolower($phrase)); 
             if ($pos > -1) break;
         }

         $startPos = 0; 
         if ($pos > $radius) { 
             $startPos = $pos - $radius; 
         } 

         $textLen = strlen($text); 

         $endPos = $pos + $phraseLen + $radius; 
         if ($endPos >= $textLen) { 
             $endPos = $textLen; 
         } 

         $excerpt = substr($text, $startPos, $endPos - $startPos); 
         if ($startPos != 0) { 
             $excerpt = substr_replace($excerpt, $ending, 0, $phraseLen); 
         } 

         if ($endPos != $textLen) { 
             $excerpt = substr_replace($excerpt, $ending, -$phraseLen); 
         } 

         return $excerpt; 
   } 

Fremhæv funktion

function highlight($c,$q){ 
$q=explode(' ',str_replace(array('','\\','+','*','?','[','^',']','$','(',')','{','}','=','!','<','>','|',':','#','-','_'),'',$q));
for($i=0;$i<sizeOf($q);$i++) 
    $c=preg_replace("/($q[$i])(?![^<]*>)/i","<span class=\"highlight\">\${1}</span>",$c);
return $c;}


  1. Samlet strengsammenkædning i Oracle 10g

  2. SÆT SQLBLANKLINES:Sådan tillades tomme linjer i SQLcl &SQL*Plus

  3. Fremmednøglebegrænsning kan forårsage cyklusser eller flere kaskadestier?

  4. Hvordan forbindes i java som SYS til Oracle?