Please explain this php code, about the preg_replace_callback() function

WBOY
Release: 2016-08-04 09:20:02
Original
1156 people have browsed it

<code>$str =  preg_replace_callback(
            "#\\\u([0-9a-f]{4})#i", 
            function($matchs) 
            { 
                return  iconv('UCS-2BE', 'UTF-8',  pack('H4',  $matchs[1])); 
            }, 
            $str); 
</code>
Copy after login
Copy after login

我搜了搜相关资料,懂了个大概,但是精髓部分还是不明白。
1)preg_replace_callback()函数第一个参数应该是个正则表达式,用来匹配相关字符。但是,其中的两个‘#’和最后的那个i我不是很明白,是为了什么?
2)第二个参数是个闭包里面的参数$matchs是系统指定的?还是随便给个参数名都行?例如function($a),还有这个地方只能是闭包么,可以用函数改写么?
3)关于这个$matchs,经过我测试输出,它是个数组.matchs[0]是u8fd8,matchs[1]是8fd8。这是怎么做到的?利用前面那个正则表达式我只能匹配到matchs[0]的结果,去掉u的工作和再用matchs[1]保留去掉u后的结果是谁做的?莫非是那个‘#’后的i?

<code>Array
(
    [0] => \u8fd8
    [1] => 8fd8
)</code>
Copy after login
Copy after login

4)`iconv('UCS-2BE', 'UTF-8', pack('H4', $matchs[1]));经过输出,iconv()函数的返回值是还这个iconv()函数内部是怎么组装出来还的呢?内部的pack函数中的H4作用是什么?是怎么加到8FD8前面的。

新手问题较多请大神们,不吝赐教。感激不尽!

回复内容:

<code>$str =  preg_replace_callback(
            "#\\\u([0-9a-f]{4})#i", 
            function($matchs) 
            { 
                return  iconv('UCS-2BE', 'UTF-8',  pack('H4',  $matchs[1])); 
            }, 
            $str); 
</code>
Copy after login
Copy after login

我搜了搜相关资料,懂了个大概,但是精髓部分还是不明白。
1)preg_replace_callback()函数第一个参数应该是个正则表达式,用来匹配相关字符。但是,其中的两个‘#’和最后的那个i我不是很明白,是为了什么?
2)第二个参数是个闭包里面的参数$matchs是系统指定的?还是随便给个参数名都行?例如function($a),还有这个地方只能是闭包么,可以用函数改写么?
3)关于这个$matchs,经过我测试输出,它是个数组.matchs[0]是u8fd8,matchs[1]是8fd8。这是怎么做到的?利用前面那个正则表达式我只能匹配到matchs[0]的结果,去掉u的工作和再用matchs[1]保留去掉u后的结果是谁做的?莫非是那个‘#’后的i?

<code>Array
(
    [0] => \u8fd8
    [1] => 8fd8
)</code>
Copy after login
Copy after login

4)`iconv('UCS-2BE', 'UTF-8', pack('H4', $matchs[1]));经过输出,iconv()函数的返回值是还这个iconv()函数内部是怎么组装出来还的呢?内部的pack函数中的H4作用是什么?是怎么加到8FD8前面的。

新手问题较多请大神们,不吝赐教。感激不尽!

1 i 正则通配符 意思是 不区分大小写
2 $match变量名而已 可以随便写。一般这样使用
preg_replace_callback ( "/表达式/通配符", array($this,"a"), $string);
function a($m){

}
3 你没给匹配的字符串 无法回答

  1. # 号可以替换成任何特殊符号, 只要不常见的就行, 你用 "~", "/", "#" 都是一样的, i表示不区分大小写

  2. 随便写, 不是一定要$match

  3. iconv是编码转换函数

上面这段代码的功能只是用来把UCS-2BE字符格式的字符串转换成汉字的。

http://bbs.csdn.net/topics/39...

Related labels:
php
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template