Maison > développement back-end > tutoriel php > Partage d'expressions régulières PHP

Partage d'expressions régulières PHP

小云云
Libérer: 2023-03-21 22:40:02
original
2501 Les gens l'ont consulté

对于开发人员来说,正则表达式是一个非常有用的功能,它提供了 查找,匹配,替换 句子,单词,或者其他格式的字符串。本篇文章主要介绍了15个超实用的php正则表达式,需要的朋友可以参考下。

1、 验证域名检验一个字符串是否是个有效域名.

$url = "http://baidu.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."; 
}
Copier après la connexion
Copier après la connexion

2、从一个字符串中 突出某个单词

这是一个非常有用的在一个字符串中匹配出某个单词 并且突出它,非常有效的搜索结果

$text = "Sample sentence from website, 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", &#39;<span style="background:#5fc9f6">1</span>&#39;, $text); 
echo $text;
Copier après la connexion

突出查询结果在你的 WordPress 博客里就像刚才我说的,上面的那段代码可以很方便的搜索出结果,而这里是一个更好的方式去执行搜索在某个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(&#39;/(&#39;.implode(&#39;|&#39;, $keys) .&#39;)/iu&#39;, 
    &#39;<strong>\0</strong>&#39;, 
    $title); 
?> Save the search.php file and open style.css. Append the following line to it: 
strong.search-excerpt { background: yellow; }
Copier après la connexion
Copier après la connexion

3、从HTML文档中获得全部图片

如果你曾经希望去获得某个网页上的全部图片,这段代码就是你需要的,你可以轻松的建立一个图片下载机器人

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

4、删除重复字母

经常重复输入字母? 这个表达式正适合.

$text = preg_replace("/s(w+s)1/i", "$1", $text);
Copier après la connexion
Copier après la connexion

5、删除重复的标点

功能同上,但只是面对标点,白白重复的逗号

$text = preg_replace("/.+/i", ".", $text);
Copier après la connexion
Copier après la connexion

6、匹配一个XML或者HTML标签

这个简单的函数有两个参数:第一个是你要匹配的标签,第二个是包含XML或HTML的变量,再强调下,这个真的很强大

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

 return $matches[1]; 
}
Copier après la connexion
Copier après la connexion

7、匹配具有属性值的XML或者HTML标签

这个功能和上面的非常相似,但是它允许你匹配的标签内部有属性值,例如你可以轻松匹配

function get_tag( $attr, $value, $xml, $tag=null ) { 
 if( is_null($tag) ) 
  $tag = &#39;\w+&#39;; 
 else 
  $tag = preg_quote($tag); 

 $attr = preg_quote($attr); 
 $value = preg_quote($value); 

 $tag_regex = "/<(".$tag.")[^>]*$attr\s*=\s*". 
        "([&#39;\"])$value\\2[^>]*>(.*?)<\/\\1>/" 

 preg_match_all($tag_regex, 
         $xml, 
         $matches, 
         PREG_PATTERN_ORDER); 

 return $matches[3]; 
}
Copier après la connexion
Copier après la connexion

8、匹配十六进制颜色值

web开发者的另一个有趣的工具,它允许你匹配和验证十六进制颜色值.

$string = "#555555"; 
if (preg_match(&#39;/^#(?:(?:[a-fd]{3}){1,2})$/i&#39;, $string)) { 
echo "example 6 successful."; 
}
Copier après la connexion
Copier après la connexion

9、查找页面 title

这段代码方便查找和打印 网页 和 之间的内容

$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);
Copier après la connexion
Copier après la connexion

10、解释 Apache 日志

大多数网站使用的都是著名的Apache服务器,如果你的网站也是,那么使用PHP正则表达式解析 apache 服务器日志 怎么样?

//Logs: Apache web server 
//Successful hits to HTML files only. Useful for counting the number of page views. 
&#39;^((?#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)[^"]*)"$&#39; 

//Logs: Apache web server 
//404 errors only 
&#39;^((?#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)[^"]*)"$&#39;
Copier après la connexion
Copier après la connexion

11、使用智能引号代替双引号

如果你是一个印刷爱好者,你将喜欢这个允许用智能引号代替双引号的正则表达式,这个正则被WORDPRESS在其内容上使用

preg_replace(&#39;B"b([^"x84x93x94rn]+)b"B&#39;, &#39;?1?&#39;, $text);
Copier après la connexion

12、检验密码的复杂度

这个正则表达式将检测输入的内容是否包含6个或更多字母,数字,下划线和连字符. 输入必须包含至少一个大写字母,一个小写字母和一个数字

&#39;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&#39;
Copier après la connexion

13、WordPress: 使用正则获得帖子上的图片

我知道很多人是WORDPRESS的使用者,你可能会喜欢并且愿意使用 那些从帖子的内容检索下来的图像代码。使用这个代码在你的BLOG只需要复制下面代码到你的某个文件里

<?php if (have_posts()) : ?> <?php while (have_posts()) : the_post(); ?> <?php $szPostContent = $post->post_content; 
$szSearchPattern = &#39;~<img [^>]* />~&#39;; 

// 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; 
?>
Copier après la connexion
Copier après la connexion

14、自动生成笑脸图案

被WordPress使用的另一个方法, 这段代码可使你把图像自动更换一个笑脸符号

$texte=&#39;A text with a smiley &#39;; 
echo str_replace(&#39;:-)&#39;,&#39;<img src="smileys/souriant.png">&#39;,$texte);
Copier après la connexion
Copier après la connexion

15、移除图片的链接

经常重复输入字母? 这个表达式正适合.

<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <?php 
  $str = &#39; 
    <a href="http://www.jobbole.com/">jobbole</a>其他字符 
    <a href="http://www.sohu.com/">sohu</a> 
    <a href="http://www.sohu.com/"><img src="http://www.fashion-press.net/img/news/3176/mot_06.jpg" /></a> 
    <br>&#39;; 

  //echo preg_replace("/(<a.*?>)(<img.*?>)(<\/a>)/", &#39;$2&#39;, $str);  
  echo preg_replace("/(<a.*?>)(<img.*?>)(<\/a>)/", &#39;\2&#39;, $str);  
?>
Copier après la connexion
Copier après la connexion

对于开发人员来说,正则表达式是一个非常有用的功能,它提供了 查找,匹配,替换 句子,单词,或者其他格式的字符串。本篇文章主要介绍了15个超实用的php正则表达式,需要的朋友可以参考下。

1、 验证域名检验一个字符串是否是个有效域名.

$url = "http://baidu.com/"; 
if (preg_match(&#39;/^(http|https|ftp)://([A-Z0-9][A-Z0-9_-]*(?:.[A-Z0-9][A-Z0-9_-]*)+):?(d+)?/?/i&#39;, $url)) { 
  echo "Your url is ok."; 
} else { 
  echo "Wrong url."; 
}
Copier après la connexion
Copier après la connexion

2、从一个字符串中 突出某个单词

这是一个非常有用的在一个字符串中匹配出某个单词 并且突出它,非常有效的搜索结果

$text = "Sample sentence from website, 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", &#39;<span style="background:#5fc9f6">1</span>&#39;, $text); 
echo $text;
Copier après la connexion

突出查询结果在你的 WordPress 博客里就像刚才我说的,上面的那段代码可以很方便的搜索出结果,而这里是一个更好的方式去执行搜索在某个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(&#39;/(&#39;.implode(&#39;|&#39;, $keys) .&#39;)/iu&#39;, 
    &#39;<strong>\0</strong>&#39;, 
    $title); 
?> Save the search.php file and open style.css. Append the following line to it: 
strong.search-excerpt { background: yellow; }
Copier après la connexion
Copier après la connexion

3、从HTML文档中获得全部图片

如果你曾经希望去获得某个网页上的全部图片,这段代码就是你需要的,你可以轻松的建立一个图片下载机器人

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

4、删除重复字母

经常重复输入字母? 这个表达式正适合.

$text = preg_replace("/s(w+s)1/i", "$1", $text);
Copier après la connexion
Copier après la connexion

5、删除重复的标点

功能同上,但只是面对标点,白白重复的逗号

$text = preg_replace("/.+/i", ".", $text);
Copier après la connexion
Copier après la connexion

6、匹配一个XML或者HTML标签

这个简单的函数有两个参数:第一个是你要匹配的标签,第二个是包含XML或HTML的变量,再强调下,这个真的很强大

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

 return $matches[1]; 
}
Copier après la connexion
Copier après la connexion

7、匹配具有属性值的XML或者HTML标签

这个功能和上面的非常相似,但是它允许你匹配的标签内部有属性值,例如你可以轻松匹配

function get_tag( $attr, $value, $xml, $tag=null ) { 
 if( is_null($tag) ) 
  $tag = &#39;\w+&#39;; 
 else 
  $tag = preg_quote($tag); 

 $attr = preg_quote($attr); 
 $value = preg_quote($value); 

 $tag_regex = "/<(".$tag.")[^>]*$attr\s*=\s*". 
        "([&#39;\"])$value\\2[^>]*>(.*?)<\/\\1>/" 

 preg_match_all($tag_regex, 
         $xml, 
         $matches, 
         PREG_PATTERN_ORDER); 

 return $matches[3]; 
}
Copier après la connexion
Copier après la connexion

8、匹配十六进制颜色值

web开发者的另一个有趣的工具,它允许你匹配和验证十六进制颜色值.

$string = "#555555"; 
if (preg_match(&#39;/^#(?:(?:[a-fd]{3}){1,2})$/i&#39;, $string)) { 
echo "example 6 successful."; 
}
Copier après la connexion
Copier après la connexion

9、查找页面 title

这段代码方便查找和打印 网页 和 之间的内容

$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);
Copier après la connexion
Copier après la connexion

10、解释 Apache 日志

大多数网站使用的都是著名的Apache服务器,如果你的网站也是,那么使用PHP正则表达式解析 apache 服务器日志 怎么样?

//Logs: Apache web server 
//Successful hits to HTML files only. Useful for counting the number of page views. 
&#39;^((?#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)[^"]*)"$&#39; 

//Logs: Apache web server 
//404 errors only 
&#39;^((?#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)[^"]*)"$&#39;
Copier après la connexion
Copier après la connexion

11、使用智能引号代替双引号

如果你是一个印刷爱好者,你将喜欢这个允许用智能引号代替双引号的正则表达式,这个正则被WORDPRESS在其内容上使用

preg_replace(&#39;B"b([^"x84x93x94rn]+)b"B&#39;, &#39;?1?&#39;, $text);
Copier après la connexion

12、检验密码的复杂度

这个正则表达式将检测输入的内容是否包含6个或更多字母,数字,下划线和连字符. 输入必须包含至少一个大写字母,一个小写字母和一个数字

&#39;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&#39;
Copier après la connexion

13、WordPress: 使用正则获得帖子上的图片

我知道很多人是WORDPRESS的使用者,你可能会喜欢并且愿意使用 那些从帖子的内容检索下来的图像代码。使用这个代码在你的BLOG只需要复制下面代码到你的某个文件里

<?php if (have_posts()) : ?> <?php while (have_posts()) : the_post(); ?> <?php $szPostContent = $post->post_content; 
$szSearchPattern = &#39;~<img [^>]* />~&#39;; 

// 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; 
?>
Copier après la connexion
Copier après la connexion

14、自动生成笑脸图案

被WordPress使用的另一个方法, 这段代码可使你把图像自动更换一个笑脸符号

$texte=&#39;A text with a smiley &#39;; 
echo str_replace(&#39;:-)&#39;,&#39;<img src="smileys/souriant.png">&#39;,$texte);
Copier après la connexion
Copier après la connexion

15、移除图片的链接

经常重复输入字母? 这个表达式正适合.

<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <?php 
  $str = &#39; 
    <a href="http://www.jobbole.com/">jobbole</a>其他字符 
    <a href="http://www.sohu.com/">sohu</a> 
    <a href="http://www.sohu.com/"><img src="http://www.fashion-press.net/img/news/3176/mot_06.jpg" /></a> 
    <br>&#39;; 

  //echo preg_replace("/(<a.*?>)(<img.*?>)(<\/a>)/", &#39;$2&#39;, $str);  
  echo preg_replace("/(<a.*?>)(<img.*?>)(<\/a>)/", &#39;\2&#39;, $str);  
?>
Copier après la connexion
Copier après la connexion

相关推荐:

PHP正则表达式的总结

php正则表达式处理方法

PHP正则表达式的基础及简单实例

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal