strtr() str_replace() substr_replace() preg_replace() 8 P* H: F0 k: s8 a' [- {8 ]9 k2 Y
strtr()的用法: - <?php
* W! m+ A$ d6 s0 X
( a- Q( C0 O5 f% K- $str = "test";& g$ S- z+ I6 a
- - t7 R- b, H& A" R
- $str1 = strtr($str, 't', 'z'); // zesz( b$ s( J; T. Q [8 j# U6 T3 o
- $str2 = strtr($str, 'tt', 'z1');// 1es1
0 `: \1 m% p {2 f- u; E* K* E - $str3 = strtr($str, 't', '');// test
3 U; y6 a$ Q8 ` - $str4 = strtr($str, 'ts', '12');// 1e21
4 i8 Y. T0 S- P$ E4 A" l
" p* T1 z! \; w9 T- ( a/ e+ \4 h" ]; @ W8 L9 u* v
- $str5 = strtr($str, array("t" => '')); // es; i, t, b# t9 `+ v0 O
- $str6 = strtr($str, array("e" => 'www', "s" => "hhh"));// twwwhhht
复制代码
% ]5 L5 [$ ]0 k! Z% a5 x 有两种传递参数的格式,一种是数组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 " @/ T1 T" N6 K' s2 ]' b$ ^* s
str_replace()的用法: mixed str_replace ( mixed $search , mixed $replace , mixed $subject) - <?php. [; h7 ? z+ M6 y' w
2 ]. y2 g, _- I ^- $str = "test";$ V3 }: t& J9 F9 f0 C
- . U( A$ W% j% l: W7 x4 x
- $str1 = str_replace('t', '', $str);// es
- X! B! H; s( u - $str2 = str_replace('es', 't', $str);// ttt2 D0 h7 P' o. X' I. c/ N# a
! p6 k" L, m$ H$ n- $str3 = str_replace(array('t', 'sa'), array('a', 'b'), $str);// aeb
* z8 O: f% \7 e8 H3 ]! G- j+ z - $str4 = str_replace(array('t', 'sa'), array('a'), $str);// ae* _4 L1 j) d, ~% D: G1 d
- $str5 = str_replace(array('t'), array('a', 'b'), $str);// aesa' _3 V" ?" Q% ]" ~) Q$ D3 r/ h. U
- $str6 = str_replace(array('t', 's'), 'e', $str);// eeee2 b' E" s$ }$ U
- * L1 r( N$ P$ r6 o- W
- $arr = array(
7 c w9 q& g. w/ G- X% j+ s2 Z9 g$ p8 A& T - 'a' => 'testa',
( {4 h& o% E, x - 'b' => 'testb',
, j ~# [# Y* d# B" E; j/ ? - 'c' => array(1 u9 v( g2 C$ D1 _6 B% G3 Y, F+ T
- 'ca' => 'tes1',
4 Q1 {, t" Q2 T3 O, M, B - 'cb' => 'tes2',8 x/ t2 F5 ?# A* H
- ),
1 o9 G4 P) S! P) @8 I - ); H9 M9 Z2 d& I$ K/ c8 b8 A4 `
s2 Z8 k0 L: m- t! X- $arr1 = str_replace('es', 't', $arr);! N% z) R& W, c
- /**
' H- Z% b+ o e8 [ - $arr1 = array(! ~6 ^3 w" r/ V" ^
- 'a' => 'ttta',- p& O+ Q: z& P f8 g# W
- 'b' => 'tttb',
: N8 I8 r0 }& F& x - 'c' => array(
" y* S% p4 w. \$ S - 'ca' => 'tes1',
# d5 k8 o8 A% v3 d6 R) X' g$ E( ^ - 'cb' => 'tes2',
3 C* S$ z7 j: c9 E" i - ),
" \& ]5 X5 F' B) |$ d( R - );
: x0 ~, D0 O& Z1 t2 C, O& K6 } - *0 m- ~1 a; G# t8 F: \" u
- *
, }% z2 B6 U$ y: U/ l5 R - */
复制代码 7 l: u ]5 |, u8 a
2 G/ `) ^$ A& i2 V/ E
1 I* a1 H. J9 }1 b! O: `( I2 Hstr_replace()在使用上比较简单: 字符串上的使用,replace直接替换掉search,注意这里就不是字符对应,是俩参数字符串对应(区别于strtr()函数)。 数组上的使用(值得一提的是:前一个对应元素替换完得到的结果再应用到下一个对应元素【会发现第9行的sa被替换成空了,而sa是第一步替换完得到的子串】。): search和replace都是数组的时候:如果是两个数组元素个数相等,各个参数对应(如第8行)。如果search个数大于replace的话,多余的就被空字符串替换(如第9行)。 search是数组,replace是字符串的话,就是字符串中出现的数组各个值被被replace替换(如第11行)。 比较意外的用法:str_replace()可以处理数组的值,结果也返回数组。。这个就可以免去程序员手动循环数组了,经测试,只能对一维数组生效(如第22行)。 4 x; h* l% g5 P W5 }) F6 I
substr_replace()用于替换字符串的子串。使用方法:是指定处理字符串的开始和长度,然后替换掉这段区间。也可以替换数组。。 mixed substr_replace ( mixed $string , mixed $replacement , mixed $start [, mixed $length ] ) 举个例子: - <?php4 ~, T. Y! a! b, |
5 e* ?& ?+ H" c( o# s- $str = "test";5 |* }- J7 C- U3 l K1 M" @4 y
4 T' T8 i& n( n, t! ^) ?6 B- echo substr_replace($str, 'zzz', 1, 2);// tzzzt
& ~2 O) i" C4 Z8 \+ _ - N" G, R+ B. b
- $arr = array(
0 Q7 S3 W$ @# I/ F - 'a' => 'what',& L6 a& a% C' n& F; D; \
- 'b' => 'are',- N# y+ ]: g( W5 U# R
- 'c' => array(
2 u% a) q' v7 [* {7 i - 'ca' => '11',
( Z3 w% ?( P' o8 L% o' c6 Q - 'cb' => '22',2 t* Q, c1 S" y n. t) e5 X
- ),
. J1 ^9 [+ G5 {" B - );8 p3 u' U. ~1 n7 j) o8 z% I$ B1 n0 o
8 o; g; F- [9 ? o8 |4 a- $arr1 = substr_replace($arr, 'ok', 0, 1);
$ J0 n8 ]: |' X$ f - /**0 t# W, G k8 y3 l
- $arr1 = array(1 C. A$ t1 T1 b) C8 J. ?6 `1 ]2 B r
- 'a' => 'okhat',4 z; G5 p; Q+ }
- 'b' => 'okre',2 Q- v$ H# ~" `, |
- 'c' => 'okarry'% d# F- v. J5 S( V% x. _. n
- );% Q4 w' i3 c5 M/ w% H
- */
8 J9 K$ _6 M( T4 z5 i j
复制代码 - z) _! K1 o- L+ F6 G! H- [, M
数组替换的时候,也是处理一维数组的字符串值。。 9 Y2 ]3 q% g; N$ K3 |% N/ o( h" }
preg_replace()的用法 正则这个就尼玛太强大了,主要用于匹配特定格式的时候,否则推荐直接使用str_replace()函数。 这就举个稍微简单的例子,一段话中间夹杂着一个手机号码(简单匹配,就是以1开头的11位数字,前后不能是数字),想要在手机号码前边加上( mobile: )字样。 - <?php6 r6 _# b$ c% n& C0 g) @
- C( C* K$ c0 z$ U
- $arr = array(
, x1 m5 s6 Y( Z: s3 r - 'a' => 'XXX25012349999XXX',// 不是以1开头
M/ o# |6 y; A# } - 'b' => 'XXX13188887777XXX',
3 g4 t# x! ^% G9 N- C - 'c' => 'XXXX918811113333XXXXX',- x. M' O0 {: ~
- 'd' => 'XXXX188111133331XXXXX',& t: X; A5 u7 x( ?4 C. U) b% i
- );
+ [4 [7 |! j1 V" D. g+ K7 | - / e/ o# N/ |, S$ N x, `
- $re = preg_replace('/([^0-9])(1\d{10})([^0-9])/', '$1 mobile:$2 $3', $arr);// 利用$1,$3
4 K2 D; }1 q6 }+ H: B% g
% x! c" r" ~& ]$ j2 E1 s M- $re1 = preg_replace('/(?<=[^0-9])(1\d{10})(?=[^0-9])/', ' mobile:$1 ', $arr);// 使用向前向后匹配,直接匹配的$1电话号
8 w. F9 A$ j9 E2 k! O2 g: b - + p( x* d2 r4 _$ u) H' B
- /**( y4 \! ^" H( g+ [1 ^( O' W
- Array
. H4 Y, Z) ]+ a; n - (6 |" S ~6 U, }" b& ^: F
- [a] => XXX25012349999XXX
0 u9 X+ O! J: i1 G: u( P: \ - [b] => XXX mobile:13188887777 XXX# S1 L; l7 ` W) U( D
- [c] => XXXX918811113333XXXXX
3 a% F5 p4 l: p& n# }5 e - [d] => XXXX188111133331XXXXX6 q, n1 ~7 ?3 M7 b7 w
- )
' \2 v4 p2 }0 A/ p8 ]# j1 q2 { - **/
复制代码 - }$ t( b" `- H w' U& y; d
4 _6 H' M/ q, U: }/ F- h
|