strtr() str_replace() substr_replace() preg_replace() . N2 T, V- ]8 b, b. f
strtr()的用法: - <?php
# l9 A' [" y' r# e8 L( A% z
$ B% {/ d! r Z2 S# S- $str = "test";5 M. e: ~. n) Q) d5 F( `" f
% S/ K) h2 s4 z4 p- $str1 = strtr($str, 't', 'z'); // zesz% y5 ]; K$ F8 p8 K0 k/ o/ r
- $str2 = strtr($str, 'tt', 'z1');// 1es1% [8 X% Q8 x6 H
- $str3 = strtr($str, 't', '');// test
4 w% M" `0 N) ]6 i - $str4 = strtr($str, 'ts', '12');// 1e21
! L3 \+ w5 t$ P. \! \7 h# G
3 r% B8 {# x; ~5 ?% K
7 @2 J7 N8 b/ B/ O- $str5 = strtr($str, array("t" => '')); // es
, L: C% m* N8 b" P- W - $str6 = strtr($str, array("e" => 'www', "s" => "hhh"));// twwwhhht
复制代码
2 a7 \6 o, V+ a0 I. V3 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
2 t5 t& |: d2 Qstr_replace()的用法: mixed str_replace ( mixed $search , mixed $replace , mixed $subject) - <?php! {; X9 n1 Z. [4 y* r
/ ^2 C' q2 H P7 M) C$ \! J- $str = "test";
& ^% B& W5 O/ T; I; ]$ q - # t( I' {( \5 f4 T
- $str1 = str_replace('t', '', $str);// es6 {" A/ S0 V1 R/ b5 R0 J' Z4 ?
- $str2 = str_replace('es', 't', $str);// ttt
$ {& S+ M# m; v6 t. k& A - - c4 ^ ?: s; R- T
- $str3 = str_replace(array('t', 'sa'), array('a', 'b'), $str);// aeb
/ ~6 y& U) W9 C$ C - $str4 = str_replace(array('t', 'sa'), array('a'), $str);// ae0 |9 R, f ~, q+ g% ]7 l, ]5 b
- $str5 = str_replace(array('t'), array('a', 'b'), $str);// aesa
* j( Q) H, i, _5 ~# C - $str6 = str_replace(array('t', 's'), 'e', $str);// eeee y% C' r/ C5 B3 t l" E9 f5 `6 u
- & c2 B2 s, i4 ^. \
- $arr = array(+ Q& F, E# c, n2 Z8 U8 z4 O, _
- 'a' => 'testa'," c% _) O! l6 L( N
- 'b' => 'testb',7 T! z( x" X( y @6 L8 F% H. _
- 'c' => array(2 [' t5 o/ S, V: v# u% x' K* O
- 'ca' => 'tes1'," \9 R% n* @# U. E9 n
- 'cb' => 'tes2',. f! C! b3 e" S z4 q% h |
- ),
9 l7 n: J4 k( I# ]1 ~ q - );! V# W% V4 X! Y4 ? x) ?
/ F$ _ |0 W4 U' q- $arr1 = str_replace('es', 't', $arr);
- J% Q; \$ Q( U5 |, f) v5 ^ - /**
# F3 y1 K3 u# ~5 U0 j6 A - $arr1 = array(. j! a2 E: e2 z) x p
- 'a' => 'ttta',) k1 {) Q6 x" }& A' u! g6 e
- 'b' => 'tttb',' L( ]2 n9 L( w0 U/ X' P/ a1 B
- 'c' => array(3 t5 E: b# v# U+ J& t" P
- 'ca' => 'tes1',# y, z2 ^% O+ R" D* `+ W4 e6 Z- ]
- 'cb' => 'tes2',: N% C, u0 G/ i
- ),0 r' x5 q, T f4 q
- );9 G0 v0 Y9 L2 G
- *
) Y. e, n4 @- f* D& _ - *7 G) s# p/ {' N P8 W4 ^) I4 l" W
- */
复制代码 1 `; B0 \5 i c% c1 v4 Y+ ]8 v
! t) {7 E& C! H& D3 B4 S2 U% P- q; `
- T- C8 w9 x5 D
str_replace()在使用上比较简单: 字符串上的使用,replace直接替换掉search,注意这里就不是字符对应,是俩参数字符串对应(区别于strtr()函数)。 数组上的使用(值得一提的是:前一个对应元素替换完得到的结果再应用到下一个对应元素【会发现第9行的sa被替换成空了,而sa是第一步替换完得到的子串】。): search和replace都是数组的时候:如果是两个数组元素个数相等,各个参数对应(如第8行)。如果search个数大于replace的话,多余的就被空字符串替换(如第9行)。 search是数组,replace是字符串的话,就是字符串中出现的数组各个值被被replace替换(如第11行)。 比较意外的用法:str_replace()可以处理数组的值,结果也返回数组。。这个就可以免去程序员手动循环数组了,经测试,只能对一维数组生效(如第22行)。
6 [$ }4 [) z0 \! R& D4 b# {* Z' Xsubstr_replace()用于替换字符串的子串。使用方法:是指定处理字符串的开始和长度,然后替换掉这段区间。也可以替换数组。。 mixed substr_replace ( mixed $string , mixed $replacement , mixed $start [, mixed $length ] ) 举个例子: - <?php, m% i* @0 W0 z, ?- O6 e
$ i/ v% Z$ [. m; {2 `5 d- $str = "test";
* `4 q/ T4 Q: H0 d, u& h- S
2 n" @# ?7 q5 v/ M9 U* n( `9 G% t! B5 ?- echo substr_replace($str, 'zzz', 1, 2);// tzzzt9 V* k& t8 Z+ B$ }9 {. C
- : P2 Q( M8 y0 U, B, B$ B& {! u
- $arr = array(
7 F6 O. `0 }: V! @4 C4 b# R5 u2 Z - 'a' => 'what',8 J$ Z1 m8 k' y! I4 j
- 'b' => 'are',
6 T8 a3 R, ^& L8 S - 'c' => array(: }: I/ f/ z/ @' r7 Z
- 'ca' => '11',
* B7 }& y) g2 C - 'cb' => '22',2 ~! ?; b' B" T- q- l- G) O
- ),! p/ l: s2 J1 o
- );% n: f8 x* I; l. `
- 7 c& }9 K" B4 v/ T
- $arr1 = substr_replace($arr, 'ok', 0, 1);9 x7 X, D! V9 ?+ f% _ M' {1 d
- /**+ V7 Q& C$ x4 O
- $arr1 = array(
& O9 W8 s9 H* v8 A8 C- I& F( \7 K - 'a' => 'okhat',
* s7 z5 {' ]0 Q, W# S - 'b' => 'okre',5 v+ t8 ^3 Y5 ?0 v
- 'c' => 'okarry'
* j+ b+ D# c. o, W- S - );! N8 E& D: q* A9 x- B, ^
- */6 T# k" o3 F- C. }+ o
复制代码
; P+ o$ e; Z+ P7 y" S数组替换的时候,也是处理一维数组的字符串值。。
& K6 @: e4 M. ypreg_replace()的用法 正则这个就尼玛太强大了,主要用于匹配特定格式的时候,否则推荐直接使用str_replace()函数。 这就举个稍微简单的例子,一段话中间夹杂着一个手机号码(简单匹配,就是以1开头的11位数字,前后不能是数字),想要在手机号码前边加上( mobile: )字样。 - <?php. Z/ N; f' i5 c% }) ?
; }' @ m8 f B' c) w- $arr = array(
$ V' a) ~7 f" v - 'a' => 'XXX25012349999XXX',// 不是以1开头* G' b* ~! `! j8 {
- 'b' => 'XXX13188887777XXX',2 h" s! k4 T/ @# ~
- 'c' => 'XXXX918811113333XXXXX',
' T' o% O' B/ | - 'd' => 'XXXX188111133331XXXXX',+ C8 P3 T n1 A9 Z% [3 e4 j' w
- );
7 d3 A5 h" a+ q
1 d+ h5 F2 d% f$ j0 ~6 _5 E: k4 A- $re = preg_replace('/([^0-9])(1\d{10})([^0-9])/', '$1 mobile:$2 $3', $arr);// 利用$1,$3
* N# u: Y+ ^$ A/ i
! q3 m* n. K8 `% t( i+ v" v- $re1 = preg_replace('/(?<=[^0-9])(1\d{10})(?=[^0-9])/', ' mobile:$1 ', $arr);// 使用向前向后匹配,直接匹配的$1电话号! U. p$ _1 h2 H% A, |
/ J; w1 x. M6 L; |6 b1 w3 o) r- /**
* ]$ V8 n9 x# Y6 b5 f U8 d j - Array1 y- B0 N, q* u
- (
, \5 |* m, N& a - [a] => XXX25012349999XXX
7 U7 a# f( a! v) V - [b] => XXX mobile:13188887777 XXX$ w* S5 D( G3 @/ ^8 C. l3 T
- [c] => XXXX918811113333XXXXX
, H r0 c: v/ `/ i - [d] => XXXX188111133331XXXXX `# S: U2 ]/ B9 ]/ Z6 y
- )
G0 J, Y; e! e7 W# T9 y+ |8 { - **/
复制代码 # T( B) j' j# X' o! @" T. N" O/ o
- G! \* Z: h$ s- {. ]4 G, ?1 h
|