利用PHP將部分內容用星號替換

2022-10-06 10:09:13 字數 1967 閱讀 4466

在最近的專案中,會碰到到某人的手機號碼隱藏中間幾位,身份證號碼只顯示末尾4位的需求。當時一開始是網上搜尋了一下,看到有人是用substr_replace這個函式來替換的,後面我也用了這個函式,但在用的時候不是很好用。

一、substr_replace

先程式設計客棧來看看這個函式的語法:

複製** **如下:

substr_replace(string,replacement,start,length)

引數描述

string

必需。規定要檢查的字串。

replacement

必需。規定要插入的字串。

start

必需。規定在字串的何處開始替換。

正數 - 在第 startwww.cppcns.com 個偏移量開始替換

負數 - 在從字串結尾的第 start 個偏移量開始替換

0 - 在字串中的第乙個字元處開始替換

charlist

可選。規定要替換多少個字元。

正數 - 被替換的字串長度

負數 - 從字串末端開始的被替換字元數

0 - 插入而非替換

1、當start與charlist都為正數的時候,非常好理解,也很符號人的邏輯,start是從0開始的,如下圖,根據條件,綠色的將是要被替換的元素

2、當start為負數,charlist為正數的時候,也挺好理解的

3、當start為正數,charlist為負數的時候,這個我一開始理解錯了

4、當start為負數,charlist為負數的時候,有乙個地方需要注意的就是:如果 start 是負數且 length 小於等於 start,則 length 為 0。這個坑挺容易踩到的

5、charlist為0的時候,就變成插入了,而不是替換,額。。。

用下來,我是感覺不是很順手,雖然說滿足我現在的需求還是可以的,但是如果將來需要一些擴充套件的話,耍起來挺吃力的,所以就想到自己構造乙個,將來用起來也方便。

二、自製的星號替換函式

複製** **如下:

replacestar($str, $start, $length = 0)

前面的兩個引數與上面的一樣,最後的引數與上面不同

1、當start與length都為正數,與substr_replace表現的一樣

2、當start為負數,length為正數,與substr_replace表現的一樣

三、原始碼分享

public static function replacestar($str, $start, $length = 0)

}elseif($length < 0)

$offset = $start - $count + 1;//起點下標減去數量,計算偏移量

$count = $offset >= 0 ? abs($length) : ($start + 1);//偏移量大於等於0說明沒有超過最左邊,小於0了說明超過程式設計客棧了最左邊,就用起點到最左邊的長度

$start = $offset >= 0 ? $offset : 0;//從最左邊或左邊的某個位置開始

}else

}else elseif($length < 0)else

} while ($i < $count)

return substr_replace($str, $star, $start, $count);

}不擅長演算法,這裡就用很普通的邏輯來展示啦,沒有用到啥數學公式。

1、if($start >= 0)這裡做start大於等於0與小於0的分支

2、在start 的分之中,分別再做length 大於0,小於0和等於0的三個分支

3、最後計算出start、count和要替換的星號字串,最後計算出的start與count都是正數,運用substr_replace做替換

四、單元測試

public function testreplacestar()

本文標題: 利用php將部分內容用星號替換

本文位址:

mysql 替換字段部分內容

mysql replace的用法 替換某欄位部分內容 mysql replace的用法 1.replace into replace into table id,name values 1 aa 2 bb 此語句的作用是向表table中插入兩條記錄。如果主鍵id為1或2不存在就相當於 insert ...

mysql 替換字段部分內容

mysql replace的用法 替換某欄位部分內容 mysql replace的用法 1.replace into replace into table id,name values 1 aa 2 bb 此語句的作用是向表table中插入兩條記錄。如果主鍵id為1或2不存在就相當於 insert ...

mysql 替換字段部分內容

mysql replace的用法 替換某欄位部分內容 mysql replace的用法 1.replace into replace into table id,name values 1 aa 2 bb 此語句的作用是向表table中插入兩條記錄。如果主鍵id為1或2不存在就相當於 insert ...