欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

详解PHP中mb_strpos的使用

程序员文章站 2022-04-10 18:32:26
mb_strpos (php 4 >= 4.0.6, php 5, php 7) mb_strpos — find position of first occ...

mb_strpos

(php 4 >= 4.0.6, php 5, php 7)
mb_strpos — find position of first occurrence of string in a string
mb_strpos — 查找字符串在另一个字符串中首次出现的位置

description

int mb_strpos ( 
  string $haystack , 
  string $needle [, 
  int $offset = 0 [, 
  string $encoding = mb_internal_encoding() ]] 
  )
//finds position of the first occurrence of a string in a string.
// 查找 string 在一个 string 中首次出现的位置。

//performs a multi-byte safe strpos() operation based on number of characters. the first character's position is 0, the second character position is 1, and so on.
// 基于字符数执行一个多字节安全的 strpos() 操作。 第一个字符的位置是 0,第二个字符的位置是 1,以此类推。

parameters

haystack

  • the string being checked.
  • 要被检查的 string。

needle

  • the string to find in haystack. in contrast with strpos(), numeric values are not applied as the ordinal value of a character.
  • 在 haystack 中查找这个字符串。 和 strpos() 不同的是,数字的值不会被当做字符的顺序值。

offset

  • the search offset. if it is not specified, 0 is used. a negative offset counts from the end of the string.
  • 搜索位置的偏移。如果没有提供该参数,将会使用 0。负数的 offset 会从字符串尾部开始统计。

encoding

  • the encoding parameter is the character encoding. if it is omitted, the internal character encoding value will be used.
  • encoding 参数为字符编码。如果省略,则使用内部字符编码。

return values

  • returns the numeric position of the first occurrence of needle in the haystack string. if needle is not found, it returns false.
  • 返回 string 的 haystack 中 needle 首次出现位置的数值。 如果没有找到 needle,它将返回 false。

example

<?php
/**
 * created by phpstorm.
 * user: zhangrongxiang
 * date: 2018/2/2
 * time: 下午11:16
 */

$str = "hello world! hello php";
$pos = mb_strpos( $str, "hello", 0, mb_internal_encoding() );
echo $pos . php_eol;//0
$pos = mb_strpos( $str, "hello", 2, mb_internal_encoding() );
echo $pos . php_eol;//13

function mb_str_replace( $haystack, $search, $replace, $offset = 0, $encoding = 'auto' ) {
  $len_sch = mb_strlen( $search, $encoding );
  $len_rep = mb_strlen( $replace, $encoding );
  
  while ( ( $offset = mb_strpos( $haystack, $search, $offset, $encoding ) ) !== false ) {
    $haystack = mb_substr( $haystack, 0, $offset, $encoding )
          . $replace
          . mb_substr( $haystack, $offset + $len_sch,
        $le = mb_strlen( $haystack ) - mb_strlen( $search ) + mb_strlen( $replace ),
        $encoding );
    //echo $le.php_eol;
    $offset = $offset + $len_rep;
    if ( $offset > mb_strlen( $haystack, $encoding ) ) {
      break;
    }
  }
  
  return $haystack;
}

$replace = mb_str_replace( "hello world !hello world !hello world !hello world !", "hello", "hi" );
echo $replace . php_eol; //hi world !hi world !hi world !hi world !

//hi php !hi php !hi php !hi php !
echo mb_str_replace( $replace, "world", "php" ) . php_eol;
echo mb_str_replace( $replace, " ", "-" ) . php_eol;

//php是世界上最好的语言????????????????????????
echo mb_str_replace( "php是世界上最好的语言????????????????????????", '????', '????', 0, mb_internal_encoding() ) . php_eol;
echo mb_str_replace( "112233445566", '22', '00' ) . php_eol;//110033445566
echo mb_str_replace( '????????????????', '????', '????1', 2, mb_internal_encoding() ) . php_eol;
echo mb_str_replace( '1111', '111', '0', 1 ) . php_eol;//10
echo mb_strlen( '????????????????' ) . php_eol;//4

//代码开发代码
echo mb_str_replace( '软件开发软件', '软件', '代码' ,0,mb_internal_encoding()) . php_eol;
//代码开发 //todo??
echo mb_str_replace( '软件开发软件', '软件', '代码' ) . php_eol;