Heim >Backend-Entwicklung >PHP-Tutorial >php字符串比较与查找方法详解

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

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOriginal
2016-07-25 08:54:061077Durchsuche
  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
复制代码


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