国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > regex > 正文

15個超實用的php正則表達式

2020-01-20 22:07:59
字體:
供稿:網(wǎng)友

在這篇文章里,我已經(jīng)編寫了15個超有用的正則表達式,WEB開發(fā)人員都應(yīng)該將它收藏到自己的工具包。

驗證域名
檢驗一個字符串是否是個有效域名.

$url = "http://komunitasweb.com/"; if (preg_match('/^(http|https|ftp)://([A-Z0-9][A-Z0-9_-]*(?:.[A-Z0-9][A-Z0-9_-]*)+):?(d+)?/?/i', $url)) {   echo "Your url is ok."; } else {   echo "Wrong url."; } 

從一個字符串中 突出某個單詞
這是一個非常有用的在一個字符串中匹配出某個單詞 并且突出它,非常有效的搜索結(jié)果

$text = "Sample sentence from KomunitasWeb, regex has become popular in web programming. Now we learn regex. According to wikipedia, Regular expressions (abbreviated as regex or  regexp, with plural forms regexes, regexps, or regexen) are written in a formal language that can be interpreted by a regular expression processor"; $text = preg_replace("/b(regex)b/i", '<span style="background:#5fc9f6">1</span>', $text); echo $text; 

突出查詢結(jié)果在你的 WordPress 博客里就像剛才我說的,上面的那段代碼可以很方便的搜索出結(jié)果,而這里是一個更好的方式去執(zhí)行搜索在某個WordPress的博客上打開你的文件 search.php ,然后找到 方法 the_title() 然后用下面代碼替換掉它

echo $title;  Now, just before the modified line, add this code:  <?php   $title   = get_the_title();   $keys= explode(" ",$s);   $title   = preg_replace('/('.implode('|', $keys) .')/iu',     '<strong>/0</strong>',     $title); ?>  Save the search.php file and open style.css. Append the following line to it:  strong.search-excerpt { background: yellow; } 

從HTML文檔中獲得全部圖片
如果你曾經(jīng)希望去獲得某個網(wǎng)頁上的全部圖片,這段代碼就是你需要的,你可以輕松的建立一個圖片下載機器人

$images = array(); preg_match_all('/(img|src)=("|')[^"'>]+/i', $data, $media); unset($data); $data=preg_replace('/(img|src)("|'|="|=')(.*)/i',"$3",$media[0]); foreach($data as $url) {   $info = pathinfo($url);   if (isset($info['extension']))   {     if (($info['extension'] == 'jpg') ||     ($info['extension'] == 'jpeg') ||     ($info['extension'] == 'gif') ||     ($info['extension'] == 'png'))     array_push($images, $url);   } } 

刪除重復字母
經(jīng)常重復輸入字母? 這個表達式正適合.

$text = preg_replace("/s(w+s)1/i", "$1", $text);

刪除重復的標點
功能同上,但只是面對標點,白白重復的逗號

$text = preg_replace("/.+/i", ".", $text); 

匹配一個XML或者HTML標簽
這個簡單的函數(shù)有兩個參數(shù):第一個是你要匹配的標簽,第二個是包含XML或HTML的變量,再強調(diào)下,這個真的很強大

function get_tag( $tag, $xml ) {  $tag = preg_quote($tag);  preg_match_all('{<'.$tag.'[^>]*>(.*?)</'.$tag.'>.'}',           $xml,           $matches,           PREG_PATTERN_ORDER);   return $matches[1]; } 

匹配具有屬性值的XML或者HTML標簽
這個功能和上面的非常相似,但是它允許你匹配的標簽內(nèi)部有屬性值,例如你可以輕松匹配 <div id=”header”>

function get_tag( $attr, $value, $xml, $tag=null ) {  if( is_null($tag) )   $tag = '/w+';  else   $tag = preg_quote($tag);   $attr = preg_quote($attr);  $value = preg_quote($value);   $tag_regex = "/<(".$tag.")[^>]*$attr/s*=/s*".         "(['/"])$value//2[^>]*>(.*?)<////1>/"   preg_match_all($tag_regex,          $xml,          $matches,          PREG_PATTERN_ORDER);   return $matches[3]; } 

匹配十六進制顏色值
web開發(fā)者的另一個有趣的工具,它允許你匹配和驗證十六進制顏色值.

$string = "#555555"; if (preg_match('/^#(?:(?:[a-fd]{3}){1,2})$/i', $string)) { echo "example 6 successful."; } 

查找頁面 title
這段代碼方便查找和打印 網(wǎng)頁 <title> 和</title> 之間的內(nèi)容

$fp = fopen("http://www.catswhocode.com/blog","r"); while (!feof($fp) ){   $page .= fgets($fp, 4096); }  $titre = eregi("<title>(.*)</title>",$page,$regs); echo $regs[1]; fclose($fp); 

解釋 Apache 日志
大多數(shù)網(wǎng)站使用的都是著名的Apache服務(wù)器,如果你的網(wǎng)站也是,那么使用PHP正則表達式解析 apache 服務(wù)器日志 怎么樣?

//Logs: Apache web server //Successful hits to HTML files only. Useful for counting the number of page views. '^((?#client IP or domain name)S+)s+((?#basic authentication)S+s+S+)s+[((?#date and time)[^]]+)]s+"(?:GET|POST|HEAD) ((?#file)/[^ ?"]+?.html?)??((?#parameters)[^ ?"]+)? HTTP/[0-9.]+"s+(?#status code)200s+((?#bytes transferred)[-0-9]+)s+"((?#referrer)[^"]*)"s+"((?#user agent)[^"]*)"$'  //Logs: Apache web server //404 errors only '^((?#client IP or domain name)S+)s+((?#basic authentication)S+s+S+)s+[((?#date and time)[^]]+)]s+"(?:GET|POST|HEAD) ((?#file)[^ ?"]+)??((?#parameters)[^ ?"]+)? HTTP/[0-9.]+"s+(?#status code)404s+((?#bytes transferred)[-0-9]+)s+"((?#referrer)[^"]*)"s+"((?#user agent)[^"]*)"$' 

使用智能引號代替雙引號
如果你是一個印刷愛好者,你將喜歡這個允許用智能引號代替雙引號的正則表達式,這個正則被WORDPRESS在其內(nèi)容上使用

preg_replace('B"b([^"x84x93x94rn]+)b"B', '?1?', $text);

檢驗密碼的復雜度
這個正則表達式將檢測輸入的內(nèi)容是否包含6個或更多字母,數(shù)字,下劃線和連字符. 輸入必須包含至少一個大寫字母,一個小寫字母和一個數(shù)字

復制代碼 代碼如下:
'A(?=[-_a-zA-Z0-9]*?[A-Z])(?=[-_a-zA-Z0-9]*?[a-z])(?=[-_a-zA-Z0-9]*?[0-9])[-_a-zA-Z0-9]{6,}z'  
 

WordPress: 使用正則獲得 帖子上的圖片
我知道很多人是WORDPRESS的使用者,你可能會喜歡并且愿意使用 那些從帖子的內(nèi)容檢索下來的圖像代碼。使用這個代碼在你的BLOG只需要復制下面代碼到你的某個文件里

<?php if (have_posts()) : ?> <?php while (have_posts()) : the_post(); ?>  <?php $szPostContent = $post->post_content; $szSearchPattern = '~<img [^>]* />~';  // Run preg_match_all to grab all the images and save the results in $aPics preg_match_all( $szSearchPattern, $szPostContent, $aPics );  // Check to see if we have at least 1 image $iNumberOfPics = count($aPics[0]);  if ( $iNumberOfPics > 0 ) {    // Now here you would do whatever you need to do with the images    // For this example the images are just displayed    for ( $i=0; $i < $iNumberOfPics ; $i++ ) {      echo $aPics[0][$i];    }; };  endwhile; endif; ?> 

自動生成笑臉圖案
被WordPress使用的另一個方法, 這段代碼可使你把圖像自動更換一個笑臉符號

$texte='A text with a smiley '; echo str_replace(':-)','<img src="smileys/souriant.png">',$texte); 

移除圖片的鏈接

<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <?php   $str = '     <a >5idev</a>其他字符     <a >sohu</a>     <a ><img src="http://www.fashion-press.net/img/news/3176/mot_06.jpg" /></a>     <br>';     //echo preg_replace("/(<a.*?>)(<img.*?>)(<//a>)/", '$2', $str);    echo preg_replace("/(<a.*?>)(<img.*?>)(<//a>)/", '/2', $str);  ?> 

以上就是15個超實用的php正則表達式,希望對大家的學習有所幫助。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 汝州市| 红河县| 玉门市| 泗阳县| 江油市| 安阳市| 罗甸县| 明水县| 玛纳斯县| 舞阳县| 安吉县| 北碚区| 汽车| 峡江县| 中西区| 铁岭县| 克东县| 凌海市| 焉耆| 云龙县| 新蔡县| 古蔺县| 中超| 赤城县| 东莞市| 陈巴尔虎旗| 铁岭市| 神池县| 赣州市| 化州市| 乃东县| 穆棱市| 台东市| 木里| 临洮县| 赣榆县| 比如县| 福海县| 浑源县| 西乌珠穆沁旗| 安陆市|