Heim >Backend-Entwicklung >PHP-Tutorial >Zusammenfassung der String-Verarbeitungsfähigkeiten im PHP-Einführungs-Tutorial (Konvertierung, Filterung, Analyse, Suche, Abfangen, Ersetzen usw.)

Zusammenfassung der String-Verarbeitungsfähigkeiten im PHP-Einführungs-Tutorial (Konvertierung, Filterung, Analyse, Suche, Abfangen, Ersetzen usw.)

高洛峰
高洛峰Original
2016-12-22 14:02:011525Durchsuche

本文实例总结了PHP字符串处理技巧。分享给大家供大家参考,具体如下:

Demo1.php

<?php
  //源代码是文本形式,页面显示是 web 形式
  $str = &#39;      PHP      &#39;;
  //清理一下两边的空格 ltrim 只清理左,rtrim只清理右边
  echo ltrim($str);
  echo &#39;<br/>&#39;;
  echo rtrim($str);
  echo &#39;<br/>&#39;;
  //两边都清理
  echo trim($str);
  //echo chop($str);
?>

Demo2.php

<?php
  $str = "This is 一站式建网站 \n This is a OneStopWeb";
  //但是,我现在想要在网页中实现换行
  //在回帖的时候,一个回车就是 \n
  //我们通过函数来实现转换过程
  echo nl2br($str);
?>

Demo3.php

<?php
  //将所有字符转换成 HTML
  $str = &#39;<strong>阅谁问君诵,水落清香浮。</strong>&#39;;
  //echo htmlentities($str);
  //我们只要转换特殊字符即可
  //echo htmlspecialchars($str);//<strong>阅谁问君诵,水落清香浮。</strong>
  echo strip_tags($str); //阅谁问君诵,水落清香浮。
?>

Demo4.php

<?php
  $str = &#39;This is "一站式建网站" \n This is a OneStopWeb&#39;;
  //对于即将插入数据库的字符串,把有问题的字符处理一下
  //echo addslashes($str); //This is \"一站式建网站\" \\n This is a OneStopWeb
  $a = addslashes($str);
  //这个 $a 就是写入数据库的,我拿出来的话,就会有 \ 这个符号
  echo stripcslashes($a);
  //首先将写进数据库的字符串通过 addslashes() 函数过滤一下,然后拿出来的时候
  //再通过 stripcslashes() 解析一下显示
?>

Demo5.php

<?php
  //将字符串转换成大写
  echo strtoupper(&#39;oneStopWeb&#39;);//ONESTOPWEB
  //将字符串转换成小写
  echo strtolower(&#39;oneStopWeb&#39;);//onestopweb
  //将第一个字母转换成大写
  echo ucfirst(&#39;oneStopWeb&#39;); //OneStopWeb
?>

Demo6.php

<?php
  $str = &#39;oneStopWeb&#39;;
  //echo str_pad($str,11).&#39;is good!&#39;; //oneStopWeb is good!
  //oneStopWeb###
  //echo str_pad($str,13,&#39;#&#39;)
  echo str_pad($str,18,&#39;#&#39;,STR_PAD_BOTH);
  echo &#39;<br/>&#39;;
  echo str_pad($str,18,&#39;#&#39;,STR_PAD_LEFT);
  echo &#39;<br/>&#39;;
  echo str_pad($str,18,&#39;#&#39;,STR_PAD_RIGHT);
/**
 * ####oneStopWeb####
 * ########oneStopWeb
 * oneStopWeb########
 * */
?>

Demo7.php

<?php
  //explode -- 使用一个字符串分割另一个字符串
  //返回的是一个数组
  //explode 第一参数是分割字符串,第二个参数是要被分割的字符串
  $email = explode(&#39;@&#39;,&#39;oneStopWeb@163.com&#39;);
  //print_r($email); //Array ( [0] => oneStopWeb [1] => 163.com )
  //分割完了之后,我经过一轮筛选,还要重新组合
// $arr = array(&#39;oneStop&#39;,&#39;@&#39;,&#39;163.com&#39;);
// $str = implode(&#39;&&#39;,$arr);
// echo $str;//oneStop&@&163.com
  $str = implode(&#39; - &#39;,$email);
  echo $str; //oneStopWeb - 163.com
?>

Demo8.php

<?php
// $str = &#39;I will be back&#39;;
// $arr = explode(&#39; &#39;,$str);
// print_r($arr); //Array ( [0] => I [1] => will [2] => be [3] => back )
  $str = &#39;I,will.be#back&#39;;
  $tok = strtok($str,&#39;,.#&#39;);
  //echo $tok;
  while($tok){
    echo $tok.&#39;<br/>&#39;;
    $tok = strtok(&#39;,.#&#39;);
  }
// $str = &#39;I will be back&#39;;
// $tok = strtok($str,&#39; &#39;);
// //echo $tok;
// while($tok){
//   echo $tok.&#39;<br/>&#39;;
//   $tok = strtok(&#39; &#39;);
// }
// $tok = strtok(&#39; &#39;);
// echo $tok;//Iwill
// //指针没有下移,而是重新来了一次
// $tok = strtok($str,&#39; &#39;);
// echo $tok;
?>

Demo9.php

<?php
  $str = &#39;oneStopWeb@163.com&#39;;
  //中间的参数表示开始的位置,位置是从 0 开始的,最后一个参数,是取出的个数
  echo substr($str,0,5)  ;//oneSt
?>

   

Demo10.php

<?php
  //$str = &#39;oneStopWeb@163.com&#39;;
  $str = &#39;阅谁问君诵,水落清香浮。&#39;; //中文乱码
  print_r(str_split($str));
?>

   

Demo11.php

<?php
  $str = &#39;oneStopWeb@163.com&#39;;
  echo strrev($str); //moc.361@beWpotSeno
?>

   

Demo12.php

<?php
  //通过 == 来比较字符串是否一致
  //最后的返回值是布尔值
  //echo &#39;a&#39; == &#39;a&#39;;
  //比较两个字符串
  //echo strcmp(&#39;a&#39;,&#39;b&#39;);
// if(strcmp(&#39;a&#39;,&#39;a&#39;) == 0){
//   echo &#39;相等&#39;;
// }
  //echo strcasecmp(&#39;B&#39;,&#39;b&#39;); //不区别大小写
  //目前是非自然排序
  //echo strcmp(&#39;2&#39;,&#39;10&#39;);//1
  //如果按照自然排序方式比较呢?
  echo strnatcmp(&#39;2&#39;,&#39;10&#39;);//-1
?>

   

Demo13.php

<?php
  //strspn
  //后面两个数字的参数,是从第几位开始,取多少位
  echo strspn(&#39;one&#39;,&#39;oneStopWeb@163.com&#39;,1,5);
?>

   

Demo14.php

<?php
  //测试字符串的长度
  echo strlen(&#39;oneStopWeb@163.com&#39;) ;
?>

   

Demo15.php

<?php
  //测试字符串出现的频率
  echo substr_count(&#39;oneStopWeb@163.com&#39;,&#39;o&#39;);
?>

   

Demo16.php

<?php
  //从指定的字符串开始输出之后的字符串
  echo strstr(&#39;oneStopWeb@163.com&#39;,&#39;@&#39;);
  //不区别大小写的
  echo stristr(&#39;oneStopWeb@163.com&#39;,&#39;s&#39;);
?>

   

Demo17.php

<?php
  //查找某字符串最先出现的位置
  //位置是从第 0 个位置开始计算,W第一次出现在第 7 个位置上
  echo strpos(&#39;oneStopWeb@163.com&#39;,&#39;W&#39;);
  //最后出现的位置
  echo strrpos(&#39;oneStopWeb@163.com&#39;,&#39;o&#39;);
?>

   

Demo18.php

<?php
  //字符串替换
  //第一个参数表示要查找的字符串(部分)
  //第二个参数表示要替换成的字符串(部分)
  //第三个参数表示原来的被替换的完整字符串
  //echo str_replace(&#39;one&#39;,&#39;yi&#39;,&#39;oneStopWeb@163.com&#39;);//yiStopWeb@163.com
  //str_ireplace 是不区分大小写
  //echo str_ireplace(&#39;oNe&#39;,&#39;yi&#39;,&#39;oneStopWeb@163.com&#39;);//yiStopWeb@163.com
  //从第一个位置开始(参数3),取出 5 个来(参数4),将它替换成 ###(参数2)
  echo substr_replace(&#39;oneStopWeb@163.com&#39;,&#39;###&#39;,0,5);
?>

   

Demo19.php

<?php
  //取中文长度
  $str = &#39;阅谁问君诵,水落清香浮。&#39;;
  //用普通的 strlen 取一个中文字,就算两个
  //echo strlen($str) ;
  //使用 mb_strlen 来取中文,有第二个参数,字符编码
  echo mb_strlen($str,&#39;GBK&#39;);//12
  //如果你使用普通的 strlen 这个函数,我取 1 个字符
  //采用 mb_substr 来取中文字符
  echo mb_substr($str,2,1,&#39;GBK&#39;);//问
?>

   

Demo20.php

<?php
  $str = &#39;阅谁问君诵,水落清香浮。&#39;;
  //求出 o 最先出现的位置
  //中文的算法,两个字符一个中文字
  //mb 就算一个
  //echo strpos($str,&#39;问&#39;);//4
  //按中文一个字符来计算,这样不会出现半个中文的状态
  echo mb_strpos($str,&#39;问&#39;,0,&#39;GBK&#39;);
?>

   

Demo21.php

<?php
// $str = &#39;阅谁问君诵,水落清香浮。&#39;  ;
// echo mb_substr($str,0,1,&#39;GBK&#39;);
  $str =&#39;阅谁问君诵,水落清香浮。&#39;;
  //这个就无所谓用 mb_strstr
  echo strstr($str,&#39;水&#39;);
?>

   

Demo22.php

<?php
  $str =&#39;阅谁问君诵,水落清香浮。&#39;;
  echo mb_substr_count($str,&#39;问&#39;,&#39;GBK&#39;);
?>

   

希望本文所述对大家PHP程序设计有所帮助。

更多PHP入门教程之字符串处理技巧总结(转换,过滤,解析,查找,截取,替换等)相关文章请关注PHP中文网!


Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn