在PHP中,取得一个字符串中某一个字符出现的次数那是相当的简单的呀,方法也有N种,再不济我还可以把这个字符当成分隔标记进行分隔,最后求分隔出来的数组的长度就行了。
但MYSQL不行呀,没有这样的函数,还好,网上很多人给出了方案,我这里贴个最简单的:
原理:(用原始字符串的总长度 减去 将原始字符串中要统计的字符串去除后的字符串长度)再除以 要统计的字符串长度
SQL代码
- SELECT ( char_length( 'test' ) - char_length( replace('test', 't' , ''))) / (char_length('t'));
-
simplexml函数是PHP5推出的一个新的类库,可以让你很方便的操作XML,对大多数人而言,最常用的应该是simplexml_load_file和simple_load_string两种了。
但是在使用中总会有一点问题,于是做了简单的一些测试。
建立了四个文件,两个GBK,两个UTF8,
两个GBK的文件内容分别如下:
XML/HTML代码
- <?xml version="1.0" encoding="gbk" ?>
- <test>
- <test1>this is a test中文</test1>
- </test>
XML/HTML代码
- <?xml version="1.0" encoding="utf-8" ?>
- <test>
- <test1>this is a test中文</test1>
- </test>
正如你们想的那样,UTF8的文件也是这些内容。
然后开始使用 simplexml_load_file进行测试:
PHP代码
- <?php
- $xmlFile = '1.txt';
-
- $xml = @simplexml_load_file( $xmlFile );
- if ( $xml === false ){
- echo( 'failed' );
- }else{
- echo '<pre>';
- print_r( $xml );
- echo '</pre>';
- }
-
- ?>
然后,你会发现什么?
1、如果xml的encoding与文件类型不符,立刻报错
2、simplexml可以处理gbk的XML,即文件内容和encoding都为gbk(ANSI格式)
3、不管文件内容是什么,处理完了,都是UTF8.
over,测试完毕
其实想这个测试还有另外一个原因,因为thinkPHP的模版引擎的自定义扩展是采用XML来实现的,以前很多朋友在扩展的时候都会报错,那时候,我们的提示是:请使用 UTF8格式创建XML,现在,我们又可以提示:随便你想怎么创建,只要您的文件格式和encoding一致就行。