strtr() str_replace() substr_replace() preg_replace()
3 e: | s. [0 h% mstrtr()的用法: - <?php) m p! e Y+ z& j
- . n2 c% Z9 c+ U& V* b4 \- l
- $str = "test";
9 H6 c0 G4 T6 A2 Z0 r' U - % S/ E F+ u& Q- L/ ~
- $str1 = strtr($str, 't', 'z'); // zesz% r8 Z0 [# R, l; }/ W
- $str2 = strtr($str, 'tt', 'z1');// 1es13 s7 b; F0 t. x$ i+ X1 E0 S
- $str3 = strtr($str, 't', '');// test( S+ X; _# o2 x! U$ V5 a
- $str4 = strtr($str, 'ts', '12');// 1e21& Z( O9 m: D; f% r; f" ?
1 \5 ~: g% }3 ~& Y% w! H
: n2 O1 p0 _5 b, ~4 w- $str5 = strtr($str, array("t" => '')); // es
& Q) Q5 \8 N5 T' n; E1 y$ ~7 e - $str6 = strtr($str, array("e" => 'www', "s" => "hhh"));// twwwhhht
复制代码
% p$ R6 }$ l% n8 c6 O. j" o5 o 有两种传递参数的格式,一种是数组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 " \" Y, d7 Z1 L) {
str_replace()的用法: mixed str_replace ( mixed $search , mixed $replace , mixed $subject) - <?php
9 o8 E- |2 k9 U5 j6 m
2 y4 h. e% K: J: F A) K8 Z, u- $str = "test";7 P$ E* W& M0 ^
, K; {8 r8 g+ n$ r1 v9 B- $str1 = str_replace('t', '', $str);// es
- A6 a0 X) s4 U, U - $str2 = str_replace('es', 't', $str);// ttt
3 i3 E X7 w7 ?
- G3 {5 d6 U* x1 ]& [& O6 k- $str3 = str_replace(array('t', 'sa'), array('a', 'b'), $str);// aeb
( I( d3 v5 w1 \' T& Q" |1 ? k - $str4 = str_replace(array('t', 'sa'), array('a'), $str);// ae
& j/ i6 K9 C, | - $str5 = str_replace(array('t'), array('a', 'b'), $str);// aesa
& [9 J# @4 S4 d! ~3 ~- V - $str6 = str_replace(array('t', 's'), 'e', $str);// eeee, X, g# H: O* s. l7 P; }" R
- 8 z. [$ X% x* N( T; |- X
- $arr = array(
: |5 d; U: l6 U) @ - 'a' => 'testa',
* C1 x1 a7 c6 g9 n2 S% N/ r - 'b' => 'testb',
6 I# m- C# M, Z - 'c' => array(
; u a( A M. ?6 G2 H0 X8 g: C' j - 'ca' => 'tes1',
; z) e) @0 W$ Z; t4 |) l4 y: F0 P - 'cb' => 'tes2',
3 e( K6 a& y& K$ ?- Y# v$ g - ),
! @* p6 f9 j5 R: g- ^6 o - );6 E) s# w* ]: g$ c: Q, P! W
/ \% g" j/ {4 u: z- $arr1 = str_replace('es', 't', $arr);
- ^$ n( S4 P. a- s5 O) z - /**( |. U& A. r( T" h. w
- $arr1 = array(& b. _& R4 L3 y6 T, o, t
- 'a' => 'ttta',
$ d. f& b1 |( h1 R5 i( Y - 'b' => 'tttb',# [( R! H5 a9 d# i" C: r+ m# ~ H7 c
- 'c' => array(: D8 s! J* e6 m7 U
- 'ca' => 'tes1',+ g/ X- c) d t8 {
- 'cb' => 'tes2',( W/ K* S+ B8 `9 k$ c$ J" B
- ),4 P; P# D! e! Y
- );
4 i) t/ i0 o/ M - *. z$ O4 P# }: h; l1 }, X
- *% `1 P" U! E- m- B& F4 {
- */
复制代码 2 z; V* C2 r. q+ t* R
' p" @. I% M- v2 F% ]
# e7 W6 V; @0 d; U0 ustr_replace()在使用上比较简单: 字符串上的使用,replace直接替换掉search,注意这里就不是字符对应,是俩参数字符串对应(区别于strtr()函数)。 数组上的使用(值得一提的是:前一个对应元素替换完得到的结果再应用到下一个对应元素【会发现第9行的sa被替换成空了,而sa是第一步替换完得到的子串】。): search和replace都是数组的时候:如果是两个数组元素个数相等,各个参数对应(如第8行)。如果search个数大于replace的话,多余的就被空字符串替换(如第9行)。 search是数组,replace是字符串的话,就是字符串中出现的数组各个值被被replace替换(如第11行)。 比较意外的用法:str_replace()可以处理数组的值,结果也返回数组。。这个就可以免去程序员手动循环数组了,经测试,只能对一维数组生效(如第22行)。
; E5 a: b3 P5 i; H2 M# R4 qsubstr_replace()用于替换字符串的子串。使用方法:是指定处理字符串的开始和长度,然后替换掉这段区间。也可以替换数组。。 mixed substr_replace ( mixed $string , mixed $replacement , mixed $start [, mixed $length ] ) 举个例子: - <?php/ P& _3 V& u( `8 T+ R
; M% ?7 ?- _- A5 U2 B$ `3 f0 ?- $str = "test";
0 ^- W6 n. A0 {8 [) ?% l, N
& c- b$ H8 w- c* p& D/ `- y- echo substr_replace($str, 'zzz', 1, 2);// tzzzt
$ C! U% E' C' ^0 V0 T - * u* `" W: `& ?) v4 U# C5 p
- $arr = array(
5 c1 {/ r5 ~" X! R; f: D1 O* q - 'a' => 'what',
7 q- `( n1 S4 ?9 y8 P4 [( N. V0 i - 'b' => 'are',
5 K. U6 |, M3 F8 D! m - 'c' => array(, n/ K* i5 t8 @
- 'ca' => '11',
3 a3 L" `( m* B1 i2 \ - 'cb' => '22',
+ K. G5 P! `5 K2 ?% w) J7 ~/ | - ),
3 ]5 ? k- T# Q' q% g1 r E' U - );7 u, z6 p7 h4 K5 v7 ?- M2 B
- 0 K0 u, M2 C! W7 K$ ^ j9 Z
- $arr1 = substr_replace($arr, 'ok', 0, 1);
# j2 k* }! `# B+ c - /**2 P) E7 V$ @! t* |0 o; {
- $arr1 = array(
8 w0 R, ?+ w( l6 c$ ?& a& n1 X& u - 'a' => 'okhat',
5 S2 E E: u! G! V - 'b' => 'okre',( Z( m9 F! V( ] Z6 k! @* D
- 'c' => 'okarry'
% r* r9 \2 V$ { _! v - );6 H. Z0 w) E" O
- */* c7 ]9 E: m8 ?4 w1 d
复制代码
% `3 ^: y+ \' n- Z N数组替换的时候,也是处理一维数组的字符串值。。
- u9 A" O" [* [' d, c9 Z/ `preg_replace()的用法 正则这个就尼玛太强大了,主要用于匹配特定格式的时候,否则推荐直接使用str_replace()函数。 这就举个稍微简单的例子,一段话中间夹杂着一个手机号码(简单匹配,就是以1开头的11位数字,前后不能是数字),想要在手机号码前边加上( mobile: )字样。 - <?php$ w/ S) K5 O, }' h
: A9 W, J B: z& T l r- $arr = array(6 L4 e8 b; X m. j s) k
- 'a' => 'XXX25012349999XXX',// 不是以1开头# ]" [3 I X& ? ?: Y
- 'b' => 'XXX13188887777XXX',
, [8 ~3 F$ m0 |% H9 A - 'c' => 'XXXX918811113333XXXXX',
2 g4 G7 Y9 v% b - 'd' => 'XXXX188111133331XXXXX',
! p' H2 N R+ |2 x5 y" w - );
1 l6 O0 a/ t$ j7 t - % @4 S: F# Y- ` F
- $re = preg_replace('/([^0-9])(1\d{10})([^0-9])/', '$1 mobile:$2 $3', $arr);// 利用$1,$3# D& q# ?- L( f5 Z
- ( ~% O. I5 m- v* }
- $re1 = preg_replace('/(?<=[^0-9])(1\d{10})(?=[^0-9])/', ' mobile:$1 ', $arr);// 使用向前向后匹配,直接匹配的$1电话号/ Q( w! b' P& [8 w
- 8 C- T+ N) u* X! \- a- E
- /**7 ]+ }# N3 w/ ^3 q: H1 Y
- Array
& `) ]- D; s$ {% O) z; f - (8 i8 p3 B( B8 e# M4 G9 K. A
- [a] => XXX25012349999XXX3 `' q5 o. v7 _7 v0 V
- [b] => XXX mobile:13188887777 XXX
9 n2 g$ V, {/ n2 X5 U% ?6 ~ - [c] => XXXX918811113333XXXXX% a8 e4 h0 H @% `
- [d] => XXXX188111133331XXXXX! ]- ]+ O+ a4 m% X- S6 H1 W
- )( V9 }0 F+ k" Z0 S1 p* z. [- G
- **/
复制代码
8 J" ]' y' @4 D+ {( z) |
8 p3 [; W% e! s0 Y& ~+ H1 x |