strtr() str_replace() substr_replace() preg_replace()
+ I/ Y% o* X' O" u. ]* ] D( Fstrtr()的用法: - <?php: Y4 k7 q6 M# b2 W1 K7 n2 ?
- - s) u1 ]/ R P% r0 U3 ^6 z' F
- $str = "test";" K7 Z1 _, d8 X6 r- l8 s* f
6 v: G! C' f, f9 L1 S m- s6 A- $str1 = strtr($str, 't', 'z'); // zesz
' Q& x. q* K" f! d. v$ ` - $str2 = strtr($str, 'tt', 'z1');// 1es1
$ v7 I5 m# v. h4 }& ?# J" r - $str3 = strtr($str, 't', '');// test
6 Z* r: e# p K - $str4 = strtr($str, 'ts', '12');// 1e21( L) B4 a: M, s: P
* ^! }. g3 G# u
k0 I: T2 q; N1 x3 ^" M. \- $str5 = strtr($str, array("t" => '')); // es% K# y1 E; _7 F( A
- $str6 = strtr($str, array("e" => 'www', "s" => "hhh"));// twwwhhht
复制代码 " X1 J. _5 N: o* O0 q! `) Y
有两种传递参数的格式,一种是数组k=>v形式,一种是两个字符串的形式。 一,字符串情况 string strtr ( string $str , string $from , string $to ): search参数的每个字符和replace参数的字符对应(这个是该函数用法关键)。如果search中出现相同的字符,会按照search中最后一个字符对应的replace参数的字符代替(如第6行代码)。 如果search或者replace是空字符串,则不会被替换,原样输出(如第7行)。 二,数组k=>v情况 string strtr ( string $str , array $replace_pairs ): 这种情况比较简单,就是把字符串中的k替换成v
0 f* H4 o4 X$ k4 Fstr_replace()的用法: mixed str_replace ( mixed $search , mixed $replace , mixed $subject) - <?php" a) |( c7 c9 x$ j; p% R4 X0 q
: k* y: w- e) f( F7 Z2 U) Z- $str = "test";% L" _( s) m. _& M3 i& Y
2 O% a5 V/ V- a/ F) @+ e- $str1 = str_replace('t', '', $str);// es H% K* k4 j7 P5 s- q- x4 y( `
- $str2 = str_replace('es', 't', $str);// ttt$ {$ ~$ d+ A$ f, J
5 E# _ x& ^. ]' K8 a+ v* a. Z- $str3 = str_replace(array('t', 'sa'), array('a', 'b'), $str);// aeb7 {# E C; L7 |# j! W# r8 Y1 i
- $str4 = str_replace(array('t', 'sa'), array('a'), $str);// ae6 \8 V9 A2 k4 W8 t# \2 m
- $str5 = str_replace(array('t'), array('a', 'b'), $str);// aesa
h6 Z' T- t. G2 `: ?9 {1 Z - $str6 = str_replace(array('t', 's'), 'e', $str);// eeee) N% n2 z( O/ H+ T5 ]2 g; l0 U4 q
- $ q) [& x( k% G& F
- $arr = array(
6 @; U" S9 B* C - 'a' => 'testa',1 T* C' c E% r: H+ I6 A
- 'b' => 'testb',
- ^+ J% P+ c4 l) R- R f( L - 'c' => array(
7 [; k5 N4 i9 R- ?" J5 ]6 H - 'ca' => 'tes1',0 u9 ^( G) H) I* y6 p2 X
- 'cb' => 'tes2',
- P5 J# I& N3 r* T; F9 G0 T - ),
! f1 g: f: X+ P7 ]5 A6 S+ c - );+ T3 \1 X) k4 |& `
$ Z. }$ x' D: N! _; n- $arr1 = str_replace('es', 't', $arr);/ m( ~7 u4 I( ^6 a( w
- /**
4 W* U3 X9 a8 C; d T - $arr1 = array(. r# A( N# B8 X6 M: R; k; B
- 'a' => 'ttta',
$ ? N6 p) X% p3 u - 'b' => 'tttb',: c8 k1 v+ b4 k" v2 r/ y) p& }; |
- 'c' => array(
0 g9 V2 i3 ?0 q: ^ - 'ca' => 'tes1',) { E1 b; H. g1 {. x% X- a) i' m
- 'cb' => 'tes2',' r4 `0 L( {# I3 A. X: L
- ),
5 y6 E) e/ ~/ \, u O- |2 ?6 L; l - );
) F$ r4 i) K* q! F+ a( V# x - *8 r: ?( y- t8 N/ o, [8 d+ U8 j
- *: b0 J. Q' y# d4 ^7 W' a; F
- */
复制代码 . f9 Z" |# q B- R
% O* S( [) q( L- q
% s5 ^( H a2 Y9 [: O
str_replace()在使用上比较简单: 字符串上的使用,replace直接替换掉search,注意这里就不是字符对应,是俩参数字符串对应(区别于strtr()函数)。 数组上的使用(值得一提的是:前一个对应元素替换完得到的结果再应用到下一个对应元素【会发现第9行的sa被替换成空了,而sa是第一步替换完得到的子串】。): search和replace都是数组的时候:如果是两个数组元素个数相等,各个参数对应(如第8行)。如果search个数大于replace的话,多余的就被空字符串替换(如第9行)。 search是数组,replace是字符串的话,就是字符串中出现的数组各个值被被replace替换(如第11行)。 比较意外的用法:str_replace()可以处理数组的值,结果也返回数组。。这个就可以免去程序员手动循环数组了,经测试,只能对一维数组生效(如第22行)。 / |- O7 W) u Z, V
substr_replace()用于替换字符串的子串。使用方法:是指定处理字符串的开始和长度,然后替换掉这段区间。也可以替换数组。。 mixed substr_replace ( mixed $string , mixed $replacement , mixed $start [, mixed $length ] ) 举个例子: - <?php4 S& i6 }/ m3 C
- 7 g6 T. \; K! X8 o. q2 p
- $str = "test";4 K9 U& q* U# I: u
~- c4 s o7 z: k- echo substr_replace($str, 'zzz', 1, 2);// tzzzt
2 j5 T) t: N2 U1 a/ |4 `
7 [4 d/ r9 H, d4 \- $arr = array(7 W* V% g% m# X9 C) v7 T0 ~+ t# A4 m
- 'a' => 'what',
: w" X# A4 z7 E! R - 'b' => 'are',& |+ Q: q5 D+ b+ @
- 'c' => array(
; z2 w! {+ Z& W _; j( h - 'ca' => '11',
Z9 r: T0 S) O - 'cb' => '22',& f% z z) a1 c( A) O
- ),1 b6 k0 g0 u) d2 x5 d
- );
4 W' s. f3 V% i& O
% o% |1 H% V2 f5 }0 i- $arr1 = substr_replace($arr, 'ok', 0, 1);
4 d C0 e5 r9 H6 q0 f2 l% } - /**
% H4 R; x2 L- @" o: L- q. Y - $arr1 = array($ c) ]2 e2 a% I8 a. ?) R0 r y4 c
- 'a' => 'okhat',. W% G. ?: x$ j* A& u" Z P
- 'b' => 'okre',, G' ]' C# \; i b1 A
- 'c' => 'okarry'
& x1 p o3 K( M, z - );
8 f" Z5 ^+ l7 k" c G9 C - */
& x- u$ `* C1 [: p
复制代码
3 J) @' R& v/ f数组替换的时候,也是处理一维数组的字符串值。。
7 |, C r; C0 r9 i: f3 m4 Dpreg_replace()的用法 正则这个就尼玛太强大了,主要用于匹配特定格式的时候,否则推荐直接使用str_replace()函数。 这就举个稍微简单的例子,一段话中间夹杂着一个手机号码(简单匹配,就是以1开头的11位数字,前后不能是数字),想要在手机号码前边加上( mobile: )字样。 - <?php N$ Y+ m: X( ]! q: X% h' M7 C
- 8 u( B- A1 R6 p
- $arr = array(
5 w. A- N+ U+ p) U) A, o3 f - 'a' => 'XXX25012349999XXX',// 不是以1开头/ s4 z! y) {" K
- 'b' => 'XXX13188887777XXX',
+ J0 m/ l2 t9 y: F6 F - 'c' => 'XXXX918811113333XXXXX',
$ G1 z2 \* J7 t4 k9 v8 R5 H& h% T - 'd' => 'XXXX188111133331XXXXX',; }6 n3 Q1 O# o- i# Q% M: E1 x. j! S
- );
( R$ w/ `7 Y# ^/ o" f) {0 k! k
2 J/ K. q/ g$ p' O" J- $re = preg_replace('/([^0-9])(1\d{10})([^0-9])/', '$1 mobile:$2 $3', $arr);// 利用$1,$31 [" C) e5 ^; Y4 e# J
- , Q% j; I1 @" L0 S0 ^# ?
- $re1 = preg_replace('/(?<=[^0-9])(1\d{10})(?=[^0-9])/', ' mobile:$1 ', $arr);// 使用向前向后匹配,直接匹配的$1电话号
# k) k: e1 d" t" E, U& k0 N
$ Y" \# p! W+ O- /**7 l% E, z( x! v$ U& k
- Array
1 I$ H( i4 k5 D - ($ v( p2 Q3 A# H- H# B, L$ E
- [a] => XXX25012349999XXX
. f& t' W7 ]) s, M7 W* S - [b] => XXX mobile:13188887777 XXX
* m4 [! r3 y4 T+ G- x% U0 F - [c] => XXXX918811113333XXXXX
9 [& W* x2 p$ v2 {. u# O2 e - [d] => XXXX188111133331XXXXX
3 \- | I/ F% U5 I& K, Z( t - )1 c5 w" X1 E4 d. H
- **/
复制代码
$ @5 |: s- F( [$ _% G6 S
6 r" Q8 |- A/ W3 l. x$ s |