- A+
所属分类:PHP
在开发过程中,我们经常遇到需要将字符串转为数组的情况。PHP内置了explode函数,可以将字符串按特定的分解符分割成数组。
explode函数可以传入三个参数: 分隔符(必填),字符串(必填),数组元素数目(非必填)。
PHP5+中可以将第三个参数置为负数,返回包含除了最后n个元素的数字。
实例:
<?php $str = "one,two,three"; $arr = explode(",",$str); ?>
但是,在最近的开发遇到了如下问题:
需求如下:管理员可以在系统后台配置一个公式,如利润公式:{本金}-{成本}。在公式中,可以运算的字符包括:+-/*%()......
分析: 可以将公式作为字符串保存在数据库中,前端用户填写数据后,无论是ajax提交或者form表单提交,我们在代码中利用 str_replace 将中文替换为数据,运算表达式即可。
问题:在管理员配置公式的人为操作中,可能会将公式填错,此时,我们后台将会报错或者无法执行。因为需要判断公式在替换完成后是否含有非法字符。
技巧:正规表达式字符串含有的字符为:0-9和+-/* %().这几个字符串而已。
分析: 首先想到可以利用 explode函数来分割字符串,逐个字符串进行判断。由于explode的分隔符必须存在,无法完成,需要自己来封装函数。
函数如下:
function explodestr($str) { $length = strlen($str); $arr = array(); for($i=0;$i<$length;$i++) { $arr[$i] = mb_substr($str, $i, 1,'urft-8'); } return $arr; }
注意:使用mb_substr需开启php扩展extension=php_mbstring.dll,否则将会报错。