PHP学習文字列

不言
リリース: 2023-03-23 11:52:01
オリジナル
1492 人が閲覧しました

本篇文章介绍的内容是PHP学习中的字符串,现在分享给大家,有需要的朋友可以参考一下

创建

PHP 支持 4 种方式来创建一个字符串:单引号、双引号、heredoc 语法结构和 nowdoc 语法结构。

1. 单引号

在单引号字符串中,变量和特殊字符将不会被转义替换,除了反斜杠和单引号本身:

echo 'Arnold once said: "I\'ll be back"'; # Arnold once said: "I'll be back"

echo 'You deleted C:\\*.*?'; # You deleted C:\*.*?
ログイン後にコピー
2. 双引号

能够识别字符串中的变量和转义序列:

$juice = 'apple';
echo "$juice juice."; # apple juice.

echo "Hello \nWorld!";
#Hello
#World!
ログイン後にコピー
3. heredoc 语法结构

与双引号字符串相似。结束标记必须顶头写,不能有缩进和空格,且在结束标记末尾要有分号;标记之间的变量可以被正常解析,但是函数则不可以。常用在输出包含大量 HTML 文档的时候。

$str = 'heredoc';
$html = <<<END
<p class="container">
    <p class="row">
        <p class="col-xs-4">
            <p>$str</p>
        </p>
    </p>
</p>
END;
echo $html;

#<p class="container">
#    <p class="row">
#        <p class="col-xs-4">
#            <p>heredoc</p>
#        </p>
#    </p>
#</p>
ログイン後にコピー
4. nowdoc 语法结构

heredoc 语法结构字符串相似,但是 nowdoc 不进行变量和转义序列的解析操作。

$str = &#39;nowdoc&#39;;
$html = <<<&#39;END&#39;
<p class="container">
    <p class="row">
        <p class="col-xs-4">
            <p>$str</p>
        </p>
    </p>
</p>
END;
echo $str;

#<p class="container">
#    <p class="row">
#        <p class="col-xs-4">
#            <p>$str</p>
#        </p>
#    </p>
#</p>
ログイン後にコピー

字符串编码

在 PHP 字符串中,每个字符使用一个字节存储(内存中),这意味着 PHP 只能支持 256 的字符集,因此不支持 Unicode。

PHP 中的 string 的实现方式是一个由字节组成的数组再加上一个整数指明缓冲区长度。并无如何将字节转换成字符的信息,由程序员来决定。由于 PHP 并不特别指明字符串的编码,那字符串到底是怎样编码的呢?答案是字符串会被按照该脚本文件相同的编码方式来编码。

一般情况下,虽然 PHP 内部不支持 Unicode 字符集,但是文件支持 UTF-8 编码,绝大部分情况下不会有什么问题,但是遇到字符串编码转换的时候就有问题了,比如在一个 UTF-8 编码的 PHP 文件中,程序输出的字符数(6)并不等于实际的字符数(2):

echo strlen(&#39;中国&#39;); # 6
ログイン後にコピー
mbstring 提供了针对多字节字符串的函数,能够帮你处理 PHP 中的多字节编码。 除此以外,mbstring 还能在可能的字符编码之间相互进行编码转换。

因此,当需要操作 Unicode 字符集的字符串时候,请务必安装 mbstring 扩展,并使用相应的函数代替原生的字符串函数:

echo mb_strlen(&#39;中国&#39;, &#39;UTF-8&#39;); # 2
ログイン後にコピー
mbstring 扩展大部分的函数都需要基于一个编码(内部编码)来处理,请务必统一使用 UTF-8 编码,这个大部分可以在 PHP.INI 中配置。

对于 PHP 字符串编码问题,强烈建议:

  1. PHP 脚本文件使用 UTF-8 无 BOM 编码格式;

  2. 字符串操作使用 mbstring 扩展函数;

  3. 数据库的连接和存储使用 UTF-8 编码;

  4. HTML 文档使用 UTF-8 编码。

字符串格式化

1. 字符串去除

rtrim() — 删除字符串末端的空白字符(或者其他字符)
ltrim() — 删除字符串开头的空白字符(或其他字符)
trim() — 去除字符串首尾处的空白字符(或者其他字符)

$text = "\t\tThese are a few words :) ...  \n";
echo rtrim($text); # "\t\tThese are a few words :) ..."
echo ltrim($text); # "These are a few words :) ...  \n"
echo trim($text);  # "These are a few words :) ..."

$trimmed = trim($hello, "ld"); # "Hello Wor"
ログイン後にコピー
2. 格式化字符串以便输出

nl2br() — 在字符串所有新行之前插入 HTML 换行标记
printf() — 输出格式化字符串
sprintf() — 把格式化的字符串写入变量中

echo nl2br("hello \nworld");
#hello 
#world

printf(&#39;I need to pay $%.02lf&#39;, 1.3568); # I need to pay $1.36

$str = sprintf(&#39;I need to pay $%.02lf&#39;, 1.3568);
echo $str; # I need to pay $1.36
ログイン後にコピー

htmlspecialchars() — 将特殊字符转换为 HTML 实体
htmlentities() — 将字符转换为 HTML 转义字符

echo htmlspecialchars("<a href=&#39;test&#39;>Test</a>", ENT_QUOTES); # &lt;a href=&#039;test&#039;&gt;Test&lt;/a&gt;

echo htmlentities("A &#39;quote&#39; is <b>bold</b>"); # A &#39;quote&#39; is &lt;b&gt;bold&lt;/b&gt
ログイン後にコピー
3. 格式化字符串以便存储

stripslashes() — 反引用一个引用字符串
addslashes() — 使用反斜线引用字符串

$str = "Is your name O\&#39;reilly?";
echo stripslashes($str); # Is your name O&#39;reilly?
echo addslashes($str);   # Is your name O\&#39;reilly?
ログイン後にコピー
4. 改变字符串的字母大小写

strtolower() — 将字符串转化为小写
strtoupper() — 将字符串转化为大写
ucfirst() — 将字符串的首字母转换为大写
ucwords() — 将字符串中每个单词的首字母转换为大写

$str = "Mary Had A Little Lamb and She LOVED It So";
echo strtolower($str); # mary had a little lamb and she loved it so
echo strtoupper($str); # MARY HAD A LITTLE LAMB AND SHE LOVED IT SO

$foo = &#39;hello world!&#39;;
$foo = ucfirst($foo); # Hello world!
$foo = ucwords($foo); # Hello World!
ログイン後にコピー

字符串连接和分割

1. explode()

使用一个字符串分割另一个字符串:

$pizza  = "piece1 piece2 piece3 piece4 piece5 piece6";
$pieces = explode(" ", $pizza);
print_r($pieces); 
# Array ( [0] => piece1 [1] => piece2 [2] => piece3 [3] => piece4 [4] => piece5 [5] => piece6 )
ログイン後にコピー
2. implode() 或 join()

将一个一维数组的值拼接为字符串:

$array = array(&#39;lastname&#39;, &#39;email&#39;, &#39;phone&#39;);
echo implode(&#39;,&#39;, $array); # lastname,email,phone
ログイン後にコピー
3. substr()

返回字符串的子串:

echo substr(&#39;abcdef&#39;, 1);     # bcdef
echo substr(&#39;abcdef&#39;, 1, 3);  # bcd
echo substr(&#39;abcdef&#39;, -1, 1); # f
ログイン後にコピー

字符串比较

1. strcmp()

二进制安全字符串比较(区分大小写):

echo strcmp(&#39;jochen&#39;, &#39;Jochen&#39;); # 32,如果 str1 小于 str2 返回 < 0; 如果 str1 大于 str2 返回 > 0;如果两者相等,返回 0。
ログイン後にコピー
2. strcasecmp()

二进制安全比较字符串(不区分大小写):

echo strcasecmp(&#39;jochen&#39;, &#39;Jochen&#39;); # 0
ログイン後にコピー
3. strnatcmp()

使用自然排序算法比较字符串:

echo strnatcmp(&#39;img12.png&#39;, &#39;img10.png&#39;); # 1,
ログイン後にコピー

字符串查找和替换

1. strstr()

查找字符串的首次出现并返回字符串:

echo strstr(&#39;name@example.com&#39;, &#39;@&#39;); # @example.com
ログイン後にコピー
2. strpos()

查找字符串首次出现的位置:

$hello = &#39;Hello World&#39;;
if(strpos($hello, &#39;H&#39;) !== false) {
    echo &#39;Find&#39;;
} else {
    echo &#39;No Find&#39;;
}
ログイン後にコピー
3. str_replace()

匹配字符串并替换:

$search = "world";
$replace = "Shanghai";
$subject = "Hello world!";
echo str_replace($search, $replace, $subject); # Hello Shanghai
ログイン後にコピー
4. substr_replace()

替换指定位置的字符串:

$replace = "Shanghai";
$subject = "Hello world!";
echo substr_replace($subject, $replace, 6); # Hello Shanghai
ログイン後にコピー

正则表达式

1. preg_match()

执行一个正则表达式匹配:

$email = &#39;10001110@qq.com&#39;;
$pattern = "/^([a-zA-Z0-9])+([.a-zA-Z0-9_-])*@([.a-zA-Z0-9_-])+([.a-zA-Z0-9_-]+)+([.a-zA-Z0-9_-])$/";

if (preg_match($pattern, $email, $match)) {
    echo &#39;匹配成功<hr />&#39;;
} else {
    echo &#39;匹配失败<hr />&#39;;
}
ログイン後にコピー
2. preg_match_all()

执行一个全局正则表达式匹配:

$str = "Name: <b>John Poul</b> <br> Title: <b>PHP Guru</b>";
preg_match_all("/<b>(.*)<\/b>/U", $str, $result);
print_r($result);
# Array ( [0] => Array ( [0] => John Poul [1] => PHP Guru ) [1] => Array ( [0] => John Poul [1] => PHP Guru ) )
ログイン後にコピー
3. preg_split()

通过一个正则表达式分隔字符串:

$keywords = preg_split("/[\s,]+/", "hypertext language, programming");
print_r($keywords);
# Array ( [0] => hypertext [1] => language [2] => programming )
ログイン後にコピー
4. preg_replace()

执行一个正则表达式的搜索和替换:

$str = &#39;foo   o&#39;;
echo preg_replace(&#39;/\s\s+/&#39;, &#39; &#39;, $str); # &#39;foo o&#39;

$count = 0;
echo preg_replace(array(&#39;/\d/&#39;, &#39;/\s/&#39;), &#39;*&#39;, &#39;xp 4 to&#39;, -1 , $count); # xp***to
echo $count; # 3
ログイン後にコピー

相关推荐:

php字符串用法详解 

PHP字符串转数组和数组转字符串函数讲解 

以上がPHP学習文字列の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート