在最近的專案中,會碰到到某人的手機號碼隱藏中間幾位,身份證號碼只顯示末尾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 ...