返回介绍

5.7 字符串常用函数

发布于 2025-01-30 22:11:32 字数 9452 浏览 0 评论 0 收藏 0

数组、字符串和数据库是我们函数里面最、最、最常用的三类函数,数组和数据库我们现在还没有讲到,等讲到的时候我们再来和大家细说。

当然 PHP 的字符串函数也有很多。我们最常使用的两个系列的字符串:

  1. 单字节字符串处理函数
  2. 多字节字符串处理函数
  3. 字符串编码转换函数

我们来说说为什么要学这么多函数:

  1. 我们学的是中文,是双字节或者三字节的。老外的函数只能处理英文和数字这些单字节的字符串处理不鸟中文。达不到我们的功能需求
  2. 有的时候需要做不同字符编码间的转换,例如:把 GBK 的转为 UTF-8
  3. 英文这些字符在电脑里又是必须要处理的

因此,我们要学三个类型的常用字符串函数。

我们来贴个 PHP 手册的链接给大家看看:

  1. 多字节 iconv_* 系列: http://phpbook.phpxy.com/book.iconv.html

  2. 多字节 mb_* 系列: http://php.net/manual/zh/book.mbstring.php

  3. 处理英文系列: http://phpbook.phpxy.com/book.strings.html

看了这三个链接是不是又被吓着了?

document/2015-08-18/55d341cc9f228

当然,你不用学这么多。PHP 学院已经帮你把最常用的,需要强制背诵的准备好了。

document/2015-08-18/55d34215d28bb

之前都教过大家用,那你开始背函数吧。

PHP 常用函数:

函数名描述实例
trim()删除字符串两端的空格或其他预定义字符"$str = ""\r\nHello World!\r\n""; echo trim($str);
rtrim()删除字符串右边的空格或其他预定义字符"$str = ""Hello World!\n\n""; echo rtrim($str);"
chop()rtrim() 的别名同上
ltrim()删除字符串左边的空格或其他预定义字符"$str = ""\r\nHello World!""; echo ltrim($str);"
dirname()回路径中的目录部分(我们把它归在了字符串函数里了)echo dirname("c:/testweb/home.php");
str_pad()把字符串填充为指定的长度$str = "Hello World"; echo str_pad($str,20,""."");
str_repeat()重复使用指定字符串echo str_repeat(".",13);
str_split()把字符串分割到数组中print_r(str_split("Hello"));
strrev()反转字符串echo strrev("Hello World!");
wordwrap()按照指定长度对字符串进行折行处理"$str = ""An example on a long word is: Supercalifragulistic""; echo wordwrap($str,15);"
str_shuffle()随机地打乱字符串中所有字符echo str_shuffle("Hello World");
parse_str()将字符串解析成变量"parse_str(""id=23&name=John%20Adams"",$myArray); print_r($myArray);"
number_format()通过千位分组来格式化数字"echo number_format(""1000000""); echo number_format(""1000000"",2); echo number_format(""1000000"",2,"","",""."");"
strtolower()字符串转为小写echo strtolower("Hello WORLD!");
strtoupper()字符串转为大写echo strtoupper("Hello WORLD!");
ucfirst()字符串首字母大写echo ucfirst("hello world");
ucwords()字符串每个单词首字符转为大写echo ucwords("hello world");
htmlentities()把字符转为 HTML 实体$str = ""John & 'Adams'""; echo htmlentities($str, ENT_COMPAT);
htmlspecialchars()预定义字符转 html 编码 
nl2br()\n 转义为
标签
echo nl2br("One line.\nAnother line.");
strip_tags()剥去 HTML、XML 以及 PHP 的标签echo strip_tags("Hello world! ");
addcslashes()在指定的字符前添加反斜线转义字符串中字符$str = ""Hello, my name is John Adams." echo $str; echo addcslashes($str,'m');"
stripcslashes()删除由 addcslashes() 添加的反斜线echo stripcslashes("Hello, \my na\me is Kai Ji\m.");
addslashes()指定预定义字符前添加反斜线$str = "Who's John Adams?";echo addslashes($str);
stripslashes()删除由 addslashes() 添加的转义字符echo stripslashes("Who\'s John Adams?");
quotemeta()在字符串中某些预定义的字符前添加反斜线$str = ""Hello world. (can you hear me?)""; echo quotemeta($str);
chr()从指定的 ASCII 值返回字符echo chr(052);
ord()返回字符串第一个字符的 ASCII 值echo ord("hello");
strcasecmp()不区分大小写比较两字符串echo strcasecmp("Hello world!","HELLO WORLD!");
strcmp()区分大小写比较两字符串 
strncmp()比较字符串前 n 个字符,区分大小写 
strncasecmp()比较字符串前 n 个字符,不区分大小写int strncasecmp ( string $str1 , string $str2 , int $len )
strnatcmp()自然顺序法比较字符串长度,区分大小写int strnatcmp ( string $str1 , string $str2 )
strnatcasecmp()自然顺序法比较字符串长度,不区分大小写int strnatcasecmp ( string $str1 , string $str2 )
chunk_split()将字符串分成小块str chunk_split(str $body[,int $len[,str $end]])
strtok()切开字符串str strtok(str $str,str $token)
explode()使用一个字符串为标志分割另一个字符串array explode(str $sep,str $str[,int $limit])
implode()同 join,将数组值用预订字符连接成字符串string implode ( string $glue , array $pieces )
substr()截取字符串string substr ( string $string , int $start [, int $length ] )
str_replace()字符串替换操作,区分大小写mix str_replace(mix $search,,mix $replace,mix $subject[,int &$num])
str_ireplace()字符串替换操作,不区分大小写mix str_ireplace ( mix $search , mix $replace , mix $subject [, int &$count ] )
substr_count()统计一个字符串,在另一个字符串中出现次数int substr_count ( string $haystack , string $needle [, int $offset = 0 [, int $length ]] )
substr_replace()替换字符串中某串为另一个字符串mixed substr_replace ( mixed $string , string $replacement , int $start [, int $length ] )
similar_text()返回两字符串相同字符的数量int similar_text(str $str1,str $str2)
strchr()返回一个字符串在另一个字符串中开始位置到结束的字符串string strstr ( string $str, string $needle , bool $before_needle )
strrchr()返回一个字符串在另一个字符串中最后一次出现位置开始到末尾的字符串string strrchr ( string $haystack , mixed $needle )
stristr()返回一个字符串在另一个字符串中开始位置到结束的字符串,不区分大小写string stristr ( string $haystack , mixed $needle [, bool $before_needle = false ] )
strtr()转换字符串中的某些字符string strtr ( string $str , string $from , string $to )
strpos()寻找字符串中某字符最先出现的位置int strpos ( string $haystack , mixed $needle [, int $offset = 0 ] )
stripos()寻找字符串中某字符最先出现的位置,不区分大小写int stripos ( string $haystack , string $needle [, int $offset ] )
strrpos()寻找某字符串中某字符最后出现的位置int strrpos ( string $haystack , string $needle [, int $offset = 0 ] )
strripos()寻找某字符串中某字符最后出现的位置,不区分大小写int strripos ( string $haystack , string $needle [, int $offset ] )
strspn()返回字符串中首次符合 mask 的子字符串长度int strspn ( string $str1 , string $str2 [, int $start [, int $length ]] )
strcspn()返回字符串中不符合 mask 的字符串的长度int strcspn ( string $str1 , string $str2 [, int $start [, int $length ]] )
str_word_count()统计字符串含有的单词数mix str_word_count(str $str,[])
strlen()统计字符串长度int strlen(str $str)
count_chars()统计字符串中所有字母出现次数(0..255)mixed count_chars ( string $string [, int $mode ] )
md5()字符串 md5 编码$str = ""Hello""; echo md5($str)
iconv  
mb_substr获取字符串的部分string mb_substr ( string $str , int $start [, int $length = NULL [, string $encoding = mb_internal_encoding() ]] )
mb_http_output设置/获取 HTTP 输出字符编码mixed mb_http_output ([ string $encoding = mb_http_output() ] )
mb_strlen获取字符串的长度mixed mb_strlen ( string $str [, string $encoding = mb_internal_encoding() ] )
iconv字符串按要求的字符编码来转换string iconv ( string $in_charset , string $out_charset , string $str )
iconv_substr截取字符串的部分 
iconv_get_encoding获取 iconv 扩展的内部配置变量 
mb_substr_count统计字符串出现的次数 
mb_check_encoding检查字符串在指定的编码里是否有效 
mb_strrpos查找字符串在一个字符串中最后出现的位置 
mb_split使用正则表达式分割多字节字符串 
parse_url解释 URL 成为一个数组 

注:mb* 和 iconv* 他们可以处理多字节字符,例如:中文。

中文主要用的是 GBK 和 utf-8 两种编码格式。
GBK 和 utf-8 是两个不同的编码委员会对于汉字进行的编码的标准。

他们规定 GBK 是双字节,也就是一个汉字占用 2Bytes。
utf-8 是三字节,一个汉字占用三个字节长度的存储空间。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文