strtr() str_replace() substr_replace() preg_replace() 5 a- K8 k- t* x- R
strtr()的用法: - <?php( [' x& v2 u5 D- ]; O. y
- 6 L; b+ k) X% j6 v0 m" C/ |: F! n
- $str = "test";
# b c; C" C6 B$ a - ) X1 x( |& Z9 u% j4 z
- $str1 = strtr($str, 't', 'z'); // zesz
( {. y3 v B7 B" X# i - $str2 = strtr($str, 'tt', 'z1');// 1es1; B; ^6 l1 C2 K+ }# D( N+ u
- $str3 = strtr($str, 't', '');// test2 }" R9 D% i' g- I, N4 Y9 i
- $str4 = strtr($str, 'ts', '12');// 1e217 s6 |. n" y6 B& z4 y
- # V& q6 ?5 ]& n6 M3 r) D* s H/ P
+ S+ a! V2 W/ i; d m% R- $str5 = strtr($str, array("t" => '')); // es3 y/ G i9 z; J
- $str6 = strtr($str, array("e" => 'www', "s" => "hhh"));// twwwhhht
复制代码 ( J2 D3 p& m# o5 X9 |
有两种传递参数的格式,一种是数组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
1 m6 h1 M% t* _3 i: \str_replace()的用法: mixed str_replace ( mixed $search , mixed $replace , mixed $subject) - <?php
- V0 s; [8 w: R6 f
4 B# P8 c: D6 ]" \! V! @3 I- $str = "test";) {, ]9 _. Z8 ]% g
0 N& p* e- j; A$ n- $str1 = str_replace('t', '', $str);// es
* s* |& T! ^" g. o - $str2 = str_replace('es', 't', $str);// ttt9 o( R2 h! {5 U8 o" R, i# S
+ E8 S! q' v- d/ g( S+ o- $str3 = str_replace(array('t', 'sa'), array('a', 'b'), $str);// aeb& j+ W4 h# h. X+ D. e. f* x/ v
- $str4 = str_replace(array('t', 'sa'), array('a'), $str);// ae, b* _/ ~" p& Q7 s2 f
- $str5 = str_replace(array('t'), array('a', 'b'), $str);// aesa
' p% x5 r' C' Q - $str6 = str_replace(array('t', 's'), 'e', $str);// eeee
9 a% v5 W2 n2 u6 i. ~! B0 X5 X1 \
+ `* q8 |; W/ s* h$ x: V- $arr = array($ g: [- J; U3 S
- 'a' => 'testa',
! N% l& h. K s( _) x* l9 L - 'b' => 'testb',
6 U j% Q( P; H8 B( X! W7 ^5 D$ f - 'c' => array(8 T- }* V1 m* m
- 'ca' => 'tes1',
) z% y- [- J5 I3 x - 'cb' => 'tes2',
2 j7 s; G- O+ g) H% q - ),
1 r, m/ N4 y8 W3 @! C- h - );
+ t9 _& f' H: r, n
z/ V1 G& o \$ p- $arr1 = str_replace('es', 't', $arr);
! d2 a0 l* ?: k - /**+ {6 f, n% M Y" A: }6 f8 P
- $arr1 = array(
+ V. H, s4 s2 x# V$ h - 'a' => 'ttta',7 I( E& [: G$ \1 X
- 'b' => 'tttb',; h. j) O8 ^# n5 T8 p
- 'c' => array(# t7 c" l t& ~
- 'ca' => 'tes1',& H) ~: V- R4 ?/ |; l* ~* w, \
- 'cb' => 'tes2',. k# U4 h8 @) l" \! @5 T' W3 x, I# d7 U
- ),
1 u! G1 S6 k* F; u - );
& c+ {4 q/ g* q. U. R - *+ b& o T8 l* ^2 m/ h+ i: v
- *
' q# ?+ V9 o( C) G- g - */
复制代码
, U3 W- Q4 V) Q6 D" E6 d5 z% j! E' b! e3 D2 k" a
2 O0 N7 v9 B; R' H1 c- Nstr_replace()在使用上比较简单: 字符串上的使用,replace直接替换掉search,注意这里就不是字符对应,是俩参数字符串对应(区别于strtr()函数)。 数组上的使用(值得一提的是:前一个对应元素替换完得到的结果再应用到下一个对应元素【会发现第9行的sa被替换成空了,而sa是第一步替换完得到的子串】。): search和replace都是数组的时候:如果是两个数组元素个数相等,各个参数对应(如第8行)。如果search个数大于replace的话,多余的就被空字符串替换(如第9行)。 search是数组,replace是字符串的话,就是字符串中出现的数组各个值被被replace替换(如第11行)。 比较意外的用法:str_replace()可以处理数组的值,结果也返回数组。。这个就可以免去程序员手动循环数组了,经测试,只能对一维数组生效(如第22行)。
/ O M5 b8 }4 ~6 ssubstr_replace()用于替换字符串的子串。使用方法:是指定处理字符串的开始和长度,然后替换掉这段区间。也可以替换数组。。 mixed substr_replace ( mixed $string , mixed $replacement , mixed $start [, mixed $length ] ) 举个例子: - <?php
b7 @% n1 E& i$ ?0 p% S+ | - - U7 `- ?. }- s
- $str = "test";
2 c; n2 `8 w/ r: Y5 Z2 k - % G: v5 s" }8 Y4 m$ o7 N
- echo substr_replace($str, 'zzz', 1, 2);// tzzzt
5 \, u# k8 q: a7 t! t - ! N9 F4 r7 H# m3 g- k7 N; l
- $arr = array(
* h7 P+ z1 T% N. ^# [) ?0 N0 s - 'a' => 'what',
" ~% }0 b5 R8 l7 l - 'b' => 'are',8 z$ X/ B! {! O1 D- F, s
- 'c' => array(
8 e6 O/ p% o' Q ` - 'ca' => '11',# H2 s1 S/ m+ ~' a
- 'cb' => '22',, i- ~' d$ @ {# I9 a
- ),( o& y( K: P1 X" f( i6 F
- );
9 m) `5 C$ h4 K
/ M, S9 {1 O7 o- $arr1 = substr_replace($arr, 'ok', 0, 1);
4 D5 e* I8 R9 H4 |* z$ y - /**$ T, V) K6 C y3 U' m: \
- $arr1 = array(
6 v' O0 `7 u5 L+ {5 [ - 'a' => 'okhat',
% G' I `, Y) ~; K" E# n - 'b' => 'okre',
& t$ X+ q9 l% Q" R! k( r! |7 q# n - 'c' => 'okarry'6 B; B2 E2 m/ `2 E f( C; z
- );& H5 V' u) U% Z. x# X
- */8 M0 @- F7 S4 K t$ M4 y
复制代码 / `, |7 M& ^' s- u! H5 \+ T. b9 E
数组替换的时候,也是处理一维数组的字符串值。。 & ?: }" F& [& m3 n; [- F/ r% v/ n4 _
preg_replace()的用法 正则这个就尼玛太强大了,主要用于匹配特定格式的时候,否则推荐直接使用str_replace()函数。 这就举个稍微简单的例子,一段话中间夹杂着一个手机号码(简单匹配,就是以1开头的11位数字,前后不能是数字),想要在手机号码前边加上( mobile: )字样。 - <?php, a. f. E$ a; c3 j d, T1 |: O
' ^" z" b' {1 z, d/ g- $arr = array(- }( r/ k+ c7 x2 p8 ?) |- T
- 'a' => 'XXX25012349999XXX',// 不是以1开头/ s& y# }( R' [& Z' r
- 'b' => 'XXX13188887777XXX',7 b1 n" K+ E) X$ E
- 'c' => 'XXXX918811113333XXXXX',$ l$ N8 D9 m, a9 H# n' v
- 'd' => 'XXXX188111133331XXXXX',6 w5 q6 T7 {# l8 N( l
- );
/ U, I. D; p7 O/ @" h5 Z$ } \: N0 R4 S
% M/ U8 D2 w4 Y- $re = preg_replace('/([^0-9])(1\d{10})([^0-9])/', '$1 mobile:$2 $3', $arr);// 利用$1,$3
( L0 o( E3 H- ?" g3 M: B4 U- \
& ? O: R9 Y' r4 }) Q3 j8 x: u% \- $re1 = preg_replace('/(?<=[^0-9])(1\d{10})(?=[^0-9])/', ' mobile:$1 ', $arr);// 使用向前向后匹配,直接匹配的$1电话号
- E j0 q( M/ \' m7 W: }' d1 j( P
$ K9 u+ |2 {0 z# B- /**
8 ^9 `# {: P* `- y% J" M - Array
2 J" B9 G) V* ?; R+ x) s - (
) q* L2 }- a$ I - [a] => XXX25012349999XXX2 z. R5 W: F: m8 t* N
- [b] => XXX mobile:13188887777 XXX
. M! z7 y% r; z; { - [c] => XXXX918811113333XXXXX1 B/ |# |+ V0 O9 Z
- [d] => XXXX188111133331XXXXX
) H6 g7 A5 {: B2 T" L - )
3 R) f! x: n3 ]# ? - **/
复制代码 ( T0 ~( V4 |6 z; {
- U$ U* m9 ?) |
|