|
strtr() str_replace() substr_replace() preg_replace()
- ~* F& F. \2 P% C+ z. Y* Ystrtr()的用法: - <?php6 R$ ~8 Q' a' M4 n ]* L% K
- 9 u9 J) O+ x2 I. |
- $str = "test";0 }4 [/ i0 Z7 q$ A7 l
6 `8 K0 Y, b. B+ H1 I$ ^. p- $str1 = strtr($str, 't', 'z'); // zesz
! v1 K6 L4 a; `: i" f4 U - $str2 = strtr($str, 'tt', 'z1');// 1es10 {+ h5 p- i b' T
- $str3 = strtr($str, 't', '');// test' J8 a4 v! U" s
- $str4 = strtr($str, 'ts', '12');// 1e21, p: D9 p8 G6 l' N x( ^, _& t
. m7 k+ |5 Y9 o1 q% \; b; y1 }- 4 \7 s+ Y0 A/ m) T2 g8 r$ O1 y
- $str5 = strtr($str, array("t" => '')); // es
6 Z& |8 r! @) V/ I- ]( @5 J - $str6 = strtr($str, array("e" => 'www', "s" => "hhh"));// twwwhhht
复制代码
0 s2 Y0 O- i7 N R1 U 有两种传递参数的格式,一种是数组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
2 I" ?1 {" R @4 i* rstr_replace()的用法: mixed str_replace ( mixed $search , mixed $replace , mixed $subject) - <?php
# z) v, n, ~: g" ?
5 ~& n5 H6 f' m0 F+ O* p- $str = "test";
% I8 y+ T& H' {8 J* ]: A0 d
: D% [3 T! z6 j7 Z8 M9 {- $str1 = str_replace('t', '', $str);// es8 G2 R, P$ X6 F" Y& b
- $str2 = str_replace('es', 't', $str);// ttt+ c; ~! j4 v f. {$ N+ p7 \' `
- + c8 b$ s/ }% B+ {& ^
- $str3 = str_replace(array('t', 'sa'), array('a', 'b'), $str);// aeb8 V+ ^7 a' [' }; Y$ p
- $str4 = str_replace(array('t', 'sa'), array('a'), $str);// ae
, ~% Z8 A# l6 A; ]9 @# _$ G - $str5 = str_replace(array('t'), array('a', 'b'), $str);// aesa! c6 u# a* }8 ~
- $str6 = str_replace(array('t', 's'), 'e', $str);// eeee; @; Q; J4 n( C' x( u9 c. l
- : |. K8 p! Q2 M! A6 x1 T
- $arr = array(4 f* H) I) G- t. J* Q1 E! ^4 ^
- 'a' => 'testa',
7 z" `- W( C" m, z - 'b' => 'testb',
7 u) x5 E( ?) j0 O - 'c' => array(
7 D+ e( h" O6 |* X& b - 'ca' => 'tes1',; K4 p5 d# o X
- 'cb' => 'tes2',$ f+ g' I. {( ]' |/ f/ P0 }
- ),* O, \! d1 [) u
- );: n* f {. x5 K6 v, [# v: {) j, u7 a: K
4 ~; Q) Y& l, y1 n- $arr1 = str_replace('es', 't', $arr);1 y' U" u: W% v# G* E
- /**
9 f0 m/ H5 R+ R - $arr1 = array(
) n, B# c0 i9 G* t - 'a' => 'ttta',
& S4 j8 |0 J" Y0 k2 H8 { X$ Y4 ` - 'b' => 'tttb',
) d9 w' M) k' v8 m3 A7 {4 f - 'c' => array(, w8 e) _" P/ ~& e
- 'ca' => 'tes1',
% M6 I, f6 v1 ^1 @2 l* D - 'cb' => 'tes2',% f: v. H: O D# J2 U
- ),' y' X* @% y! ~
- );1 h/ v$ T! R+ K$ b; X; r
- *& J% l) y! P8 J/ d/ ]
- *
$ e8 @% j( O' T0 k3 x }$ d - */
复制代码 1 x8 {! I1 z% n r+ `
' `& A& p% W. l1 C
! i o( Z/ h4 O
str_replace()在使用上比较简单: 字符串上的使用,replace直接替换掉search,注意这里就不是字符对应,是俩参数字符串对应(区别于strtr()函数)。 数组上的使用(值得一提的是:前一个对应元素替换完得到的结果再应用到下一个对应元素【会发现第9行的sa被替换成空了,而sa是第一步替换完得到的子串】。): search和replace都是数组的时候:如果是两个数组元素个数相等,各个参数对应(如第8行)。如果search个数大于replace的话,多余的就被空字符串替换(如第9行)。 search是数组,replace是字符串的话,就是字符串中出现的数组各个值被被replace替换(如第11行)。 比较意外的用法:str_replace()可以处理数组的值,结果也返回数组。。这个就可以免去程序员手动循环数组了,经测试,只能对一维数组生效(如第22行)。 9 N9 Z1 e( B+ d. @
substr_replace()用于替换字符串的子串。使用方法:是指定处理字符串的开始和长度,然后替换掉这段区间。也可以替换数组。。 mixed substr_replace ( mixed $string , mixed $replacement , mixed $start [, mixed $length ] ) 举个例子: - <?php
) o5 a2 o5 E8 c; F$ p3 F# k - 9 n8 o+ o( Z9 J% F) A! G
- $str = "test";
) ]8 `) T( H9 Q4 M1 C
. V" e6 |- `4 _. Y/ N- echo substr_replace($str, 'zzz', 1, 2);// tzzzt8 E# j, ~/ g ] Z
+ A1 e, |5 o l' ?- $arr = array(
2 L4 K' i9 ~+ T3 C& @ - 'a' => 'what',7 N7 f2 x+ D5 I! ?
- 'b' => 'are',! ]2 b3 [9 c5 C: `
- 'c' => array(, g) Q) H6 G: q0 `8 P
- 'ca' => '11',
, X1 E. \1 G/ t: H" d. W - 'cb' => '22',# V# ~$ P! T) C, J
- ),
. W% g/ |: R/ W - );$ k0 w7 q' n! s0 v
" l; m) C; D: v1 u( O8 _; G# K2 y- $arr1 = substr_replace($arr, 'ok', 0, 1);
. g9 i0 X' ?) Z% R& N+ b0 e O$ s9 c - /**+ O; @" I- p6 q( O1 }
- $arr1 = array( i9 c" p' `9 C, E1 Y# ?& w
- 'a' => 'okhat',
3 t* H/ ~( \: I$ M. j$ c - 'b' => 'okre',$ ?. o6 R4 N9 ?* v2 b* q
- 'c' => 'okarry'. e# l0 E* S, c$ S, @! J8 J
- );$ U4 m. @ ?# I) e& s
- */
+ G$ H6 }/ O( F9 Q9 b$ M
复制代码 ! ?5 k: v) D. l1 k5 `
数组替换的时候,也是处理一维数组的字符串值。。
. @9 G2 |, c2 }! s. M# U& ppreg_replace()的用法 正则这个就尼玛太强大了,主要用于匹配特定格式的时候,否则推荐直接使用str_replace()函数。 这就举个稍微简单的例子,一段话中间夹杂着一个手机号码(简单匹配,就是以1开头的11位数字,前后不能是数字),想要在手机号码前边加上( mobile: )字样。 - <?php9 R% r1 G$ S- G9 s0 d
- # [$ |: O% f* H4 ]4 F
- $arr = array(9 U+ T7 ?( {7 Q/ |) e' j$ i0 K/ P
- 'a' => 'XXX25012349999XXX',// 不是以1开头
% L6 P6 @* y( o! n. U' E2 ?+ v - 'b' => 'XXX13188887777XXX',
8 T8 t, [0 r! ?4 {2 c - 'c' => 'XXXX918811113333XXXXX',
+ e( o J7 w# t7 M- O3 J - 'd' => 'XXXX188111133331XXXXX',
% |! v1 f% [2 H7 p) A - );
1 I4 h, ?2 {2 [# c9 Y* n
5 c; e7 D; O8 h# w" i1 W- $re = preg_replace('/([^0-9])(1\d{10})([^0-9])/', '$1 mobile:$2 $3', $arr);// 利用$1,$3( U0 V& x% }& l8 x# Y
- - Y* J1 C- h2 b8 _. @5 q
- $re1 = preg_replace('/(?<=[^0-9])(1\d{10})(?=[^0-9])/', ' mobile:$1 ', $arr);// 使用向前向后匹配,直接匹配的$1电话号7 u8 k3 P! F- P, [+ ?1 h! b
- ; p, K) G3 U. e1 b
- /**2 q6 U b6 ~) Q! R
- Array9 `; j. d9 _3 l* a) ~9 `
- (- i r' D8 L" F' C
- [a] => XXX25012349999XXX
$ i% c* `8 [" K* [5 i5 W - [b] => XXX mobile:13188887777 XXX
* E3 k! E2 [3 q& z& R - [c] => XXXX918811113333XXXXX9 w+ u; C; b6 g
- [d] => XXXX188111133331XXXXX- b( t" G' n7 ~' i* n, i
- )+ h0 c: o9 T, w; I8 y- R
- **/
复制代码 0 y' M8 m( P* K# g+ e
% E: m: A4 E8 `3 g. ^1 s) o
|