1. 定义

  • 单引号括起来的字符串被原样输出。
  • 双引号字符串中的变量被PHP解析为变量值。

2. 获取字符串长度

strlen(string $string): int
  • 在utf-8下,汉字占3个字符,其它情况下2个字符
  • 数字、英文、小数点、下划线和空格各占一个字符

3. 截取字符串

substr(string $str, int $start, int $length): string
mb_substr(string $str, int $start, int $length, string $encoding): string
  • $encoding:设置字符串的编码格式

4. 比较字符串

4.1 按字节比较

strcmp(string $str1, string $str2): int  // 区分大小写
strcasecmp(string $str1, string $str2): int //不区分大小写

4.2 按自然排序法比较

strnatcmp(string $str1, string $str2): int  //区分大小写
strnatcasecmp(string $str1, string $str2): int //不区分大小写

自然排序法比较的是字符串的数字部分,将字符串中的数字按照大小进行排序。

4.3 按指定源字符串的位置比较

strncmp(string $str1, string $str2, int $len): int

比较字符串中的前n($len)个字符

4.4 返回值 int

返回值 说明
0 字符串相等
1 str1>str2
-1 str1<str2

5. 检索字符串

5.1 搜索字符串在另一字符串中的第一次出现

用来获取一个指定字符串在另一个字符串中首次出现的位置到后者末尾的子字符串。如果执行成功,则返回剩余字符串(存在相匹配的字符),否则返回 false。

正序开始检索

strstr(string $haystack, mixed $needle [, bool $before_needle]): string   // 区分大小写

stristr(string $haystack, mixed $needle [, bool $before_needle]): string   // 不区分大小写

后序开始检索

strrchr(string $haystack, mixed $needle): string   // 区分大小写

5.2 检索子串在字符串中出现的次数

substr_count(string $haystack, string $needle): int

6. 替换字符串

str_replace(mixed $search, mixed $replace, mixed $subject, int $count): mixed	// 区分大小写

str_ireplace(mixed $search, mixed $replace, mixed $subject, int $count): mixed	// 不区分大小写
参数 说明
mixed $search 要查找的字符串
mixed $replace 指定替换的值
mixed $subject 指定查找范围
int $count 获取执行替换的数量
substr_replace(mixed $string, mixed $replacement, mixed $start, mixed $length): mixed
参数 说明
mixed $string 要操作的原始字符串
mixed $replacement 要替换后的新字符串
mixed $start 要替换字符串开始的位置
mixed $length 指定返回的字符串长度
正数:表示从开头覆盖
负数:表示从结尾保留
0:表示“插入”而非“替代”

7. 去特殊字符

用于去除字符串开始位置和结束位置的空白字符

trim(string $str): string

用于去除字符串左边的空白字符或者指定字符串

ltrim(string $str, string $character_mask): string

用于去除字符串右边的空白字符或者指定字符串

rtrim(string $str, string $character_mask): string

8. 分割字符串

explode(string $delimiter, string $string): array
参数 说明
$delimiter 分割符
$string 要被分割的字符串
strtok(string $str, string $token): string
strtok(string $token): string

第一次调用 strtok() 函数时使用了 $str 参数。在首次调用后,该函数仅需要 $token 参数

$first_token = strtok('some/thing', '/');
$second_token = strtok('/');
var_dump($first_token, $second_token); 运行结果:
string(4) "some" string(5) "thing"

9. 合成字符串

implode(string $glue, array $pieces): string
参数 说明
$glue 指定分割符
$pieces 要被合成的数组

PHP 笔记——String 字符串的更多相关文章

  1. JavaSE 学习笔记之String字符串(十四)

    API:(Application Programming Interface,应用程序编程接口)是一些预先定义的函数,目的是提供应用程序与开发人员基于某软件或硬件的以访问一组例程的能力,而又无需访问源 ...

  2. 【学习笔记】字符串—马拉车(Manacher)

    [学习笔记]字符串-马拉车(Manacher) 一:[前言] 马拉车用于求解连续回文子串问题,效率极高. 其核心思想与 \(kmp\) 类似:继承. --引自 \(yyx\) 学姐 二:[算法原理] ...

  3. 「学习笔记」字符串基础:Hash,KMP与Trie

    「学习笔记」字符串基础:Hash,KMP与Trie 点击查看目录 目录 「学习笔记」字符串基础:Hash,KMP与Trie Hash 算法 代码 KMP 算法 前置知识:\(\text{Border} ...

  4. Java String字符串/==和equals区别,str。toCharAt(),getBytes,indexOf过滤存在字符,trim()/String与StringBuffer多线程安全/StringBuilder单线程—— 14.0

    课程概要 String 字符串 String字符串常用方法 StringBuffer StringBuilder String字符串: 1.实例化String对象 直接赋值  String str=& ...

  5. [CareerCup] 1.3 Permutation String 字符串的排列

    1.3 Given two strings, write a method to decide if one is a permutation of the other. 这道题给定我们两个字符串,让 ...

  6. 03-Java String字符串详解

    1.Java字符串String A.实例化String字符串:直接赋值(更合理一些,使用较多).使用关键字new. B.String内容的比较 // TODO Auto-generated metho ...

  7. C++学习38 string字符串的增删改查

    C++ 提供的 string 类包含了若干实用的成员函数,大大方便了字符串的增加.删除.更改.查询等操作. 插入字符串 insert() 函数可以在 string 字符串中指定的位置插入另一个字符串, ...

  8. C++学习37 string字符串的访问和拼接

    访问字符串中的字符 string 字符串也可以像字符串数组一样按照下标来访问其中的每一个字符.string 字符串的起始下标仍是从 0 开始.请看下面的代码: #include <iostrea ...

  9. java String字符串——进度1

    String字符串    在JAVA中提供了多种创建字符串对象的方法,这里介绍最简单的两种,    第一种是直接赋值,    第二种是使用String类的构造方法:    如下所示:    Strin ...

随机推荐

  1. ASP .NET登录界面用户验证码代码

    //ASP .NET用户登录界面经常用到验证码代码如下 private void Page_Load(object sender, System.EventArgs e) { // 在此处放置用户代码 ...

  2. Lua的各种资源2

    Lua Directory     This page is a top level directory of all Lua content at this wiki, grouped by top ...

  3. Codeforces Round #420 (Div. 2) A-E

    本来打算划划水洗洗睡了,突然听到这次的主人公是冈部伦太郎 石头门(<steins;gate>)主题的比赛,岂有不打之理! 石头门真的很棒啊!人设也好剧情也赞曲子也特别好听. 推荐http: ...

  4. 强连通图(最多加入几条边使得图仍为非强连通图)G - Strongly connected HDU - 4635

    题目链接:https://cn.vjudge.net/contest/67418#problem/G 具体思路:首先用tarjan缩点,这个时候就会有很多个缩点,然后再选取一个含有点数最少,并且当前这 ...

  5. C++中string.find()函数,string.find_first_of函数与string::npos

    查找字符串a是否包含子串b,不是用strA.find(strB) > 0而是strA.find(strB) != string:nposstring::size_type pos = strA. ...

  6. 老版本ubuntu更新源地址以及sources.list的配置方法 转

    转自(http://blog.csdn.net/snaking616/article/details/52966634) 1.国内可用的更新源地址: (1)中科大地址 http://mirrors.u ...

  7. 191.Number of 1Bits---位运算---《剑指offer》10

    题目链接:https://leetcode.com/problems/number-of-1-bits/description/ 题目大意:与338题类似,求解某个无符号32位整数的二进制表示的1的个 ...

  8. 2017-2018 ACM-ICPC, NEERC, Southern Subregional Contest, qualification stage

    2017-2018 ACM-ICPC, NEERC, Southern Subregional Contest, qualification stage A. Union of Doubly Link ...

  9. Android仿新浪新闻SlidingMenu界面的实现 .

    先看看原图: 如图所示,这种侧滑效果以另一种方式替代了原先tab导航的那种用户体验方式 给人耳目一新的感觉,现已被广大知名应用所效仿,如新浪新闻,网易新闻,人人网等 那么这种效果该如何实现呢?那就需要 ...

  10. UNDO自我理解总结

    [场景] 当在更新数据的时候,发现更新的值写错了,这时就需要将已经更新的地方恢复到原始数据. [基本概念] 在更新的过程中,Oracle会将原始的数据都放入到UNDO里,这样当以上情况发生后,就可以从 ...