Maison > développement back-end > tutoriel php > php字符串比较与查找方法详解

php字符串比较与查找方法详解

WBOY
Libérer: 2016-07-25 08:54:06
original
1043 Les gens l'ont consulté
  1. var_dump(0 == 'test');
  2. var_dump(0 == '');
  3. var_dump(5 > 't');
  4. var_dump(strcmp(5, 't'));
复制代码

结果为(第1~3结果是不对的,只有第4个是对的): 4bool(true) bool(true) bool(true) int(-1) 2. 字符串处理 1. 子串 $sub = substr(string, start[, length]); 2. 子串替换 $newstring = substr_replace(string, new, start[, length]); 用这个函数可以实现字符串的插入,删除操作。这个函数的start和length可以为负数。分别表示从后开始计算以及保留最后几位不替换。 3. 字符串反序 $newstring = strrev(string); 4. 重复字符串 $newstring = str_repeat(string, count); 返回一个重复count次string的新字符串。 5. 填充字符串 $newstring = str_pad(to_pad, length[, with[, type]]); 其中type有:str_pad_right(默认)、str_pad_left和str_pad_both三种;with默认为空格。函数表示把to_pad字符串用with填充为一个长度为length的字符串。 如下代码:

  1. // 子串

  2. var_dump(substr('1234567890', 8)); // 90
  3. var_dump(substr('1234567890', 0, 2)); // 12
  4. // 反方向子串
  5. var_dump(substr('1234567890', -8)); // 34567890
  6. var_dump(substr('1234567890', -8, -2)); // 345678
  7. var_dump(substr('1234567890', -8, 2)); // 34
  8. // 插入

  9. var_dump(substr_replace('1234567890', 'a', 0, 0)); // a1234567890
  10. // 删除
  11. var_dump(substr_replace('1234567890', '', 8)); // 12345678
  12. // 反方向删除
  13. var_dump(substr_replace('1234567890', '', -2, -1)); // 123456780
  14. // 替换
  15. var_dump(substr_replace('1234567890', 'a', 0, 1)); // a234567890
  16. // 反方向替换
  17. var_dump(substr_replace('1234567890', 'a', -2, -1)); // 12345678a0
  18. // 字符串反转

  19. var_dump(strrev('1234567890')); // 0987654321
  20. // 重复字符串

  21. var_dump(str_repeat('12', 3)); // 121212
  22. // 填充字符串

  23. var_dump(str_pad('a', 10, '12')); // a121212121
  24. var_dump(str_pad('a', 10, '12', str_pad_left)); // 121212121a
  25. var_dump(str_pad('a', 10, '12', str_pad_both)); // 1212a12121
复制代码

3. 分解字符串 在php中,字符串的分解用explode,合并用implode(join是implode的别名),标记用strtok。还有另一个函数slipt也可以分解(正则分解),但5.3以后版本已经不推介了。 另外php中还有一个sscanf()函数,用于读取字符串。 strtok标记时,用strtok($str, $token)来初始化,用strtok($token)来继续取值。 代码:

  1. $str = '1,2,3';

  2. $arr1 = explode(',', $str); // array('1', '2', '3')
  3. $arr2 = explode(',', $str, 2); // array('1', '2,3')
  4. $str1 = implode(',', $arr1); // '1,2,3'

  5. $str2 = strtok($str, ','); // 1

  6. $str3 = strtok(','); // 2
  7. $str4 = strtok(','); // 3
  8. // array(86, 10, 88888888, 'beijin')

  9. $arr3 = sscanf('+86(10)88888888 beijin', '+%d(%d)%d %s');
复制代码

4.字符串查找 在php中,字符串的查找有三个系列。返回位置的、返回字符串的、掩码个数匹配。其中,返回位置的的函数一共有两个,strpos()和strrpos();返回字符串的也有两个strstr()和strchr();返回掩码匹配数的函数有strspn()和strcspn()。 strpos表示从左边开始计数,返回要查找的字符串第一次出现的位置;strrpos表示从右边计数,返回要查找的字符串第一次出现的位置。 strstr表示从左边计数,返回要查找字符串第一次到结尾的子串(包括查找字符串),当查找的是字符时,可以用ascii码数字来表示字符;stristr表示不区分大小查找;strchr是strstr的别名;strrchr返回字符最后出现到结尾的子串。 strspn表示从左边计数,第一次出现非掩码之前的子串的字符数;strcspn表示从左边计数,第一次出现掩码之前的子串的字符数。 代码:

  1. $pos = strpos('this a hello world program', ' '); // 4

  2. $pos = strpos('this a hello world program', 32); // 4
  3. $pos = strrpos('this a hello world program', ' '); // 18

  4. $pos = strrpos('this a hello world program', 32); // 18
  5. $str = strstr('this a hello world program', ' '); // " a hello world program"

  6. $str = strstr('this a hello world program', 32); // " a hello world program"
  7. $str = stristr('this a hello world program', ' a'); // "a hello world program"

  8. $str = stristr('this a hello world program', 65); // "a hello world program"
  9. $str = strrchr('this a hello world program', ' '); // " program"

  10. $str = strrchr('this a hello world program', 32); // " program"
  11. $str1 = "12345 12345 12345";

  12. $len = strspn($str1, '12345'); // 5
  13. $len = strcspn($str1, ' '); // 5
复制代码


É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