首页 > 代码库 > 驼峰字符串转换成下划线样式
驼峰字符串转换成下划线样式
// 驼峰字符串转换成下划线样式$str = ‘openAPI‘;echo $str."<BR>";echo strtolower(preg_replace(‘/((?<=[a-z])(?=[A-Z]))/‘, ‘_‘, $str)).‘<br>‘;
//open_ap
正则表达式补充:
?: 不想被捕获的时候使用 可以提高程序执行速度
$string = ‘April 15, 2003‘;$pattern = ‘/(\w+) (\d+), (\d+)/i‘;$replacement = ‘${1}1,$3‘;echo preg_replace($pattern, $replacement, $string); // 结果显示 April1,2003这里就用了反向引用 $replacement 里的 ${1} 代表 (\w+) , $3代表 第2个 (\d+)这个正则表达式 里 一共有 3个 () 也就是 可以 用 $1 $2 $3 调用 3个()里的 内容。也可以使用 \1 \2 \3 来 代替 $1 $2 $3 都是一样的那接下来 如果把 代码里的 正则表达式 改成下面的$pattern = ‘/(?:\w+) (?:\d+), (\d+)/i‘; 那 这里 只有 一个 () 里的 内容 能使用 带 ?:的 ()里面内容是不会被 捕获的 ,所以 只能使用 $1 代表最后的 (\d+)
?= / ?<= 这个叫断言,只匹配一个位置
比如,你想匹配一个“人”字,但是你只想匹配中国人的人字,不想匹配法国人的人
就可以用一下表达式
(?=中国)人
所以,楼主的表达式与其他通配符连用才能起到效果。
(?=.*[a-z])\d+
这个就表示 匹配以“任意字符连着一个小写字母”开头的数字,只匹配数字。
(?<=exp)这个是放后面的。
驼峰字符串转换成下划线样式
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。