PHP实现驼峰样式字符串(首字母大写)转换成下划线
本文实例讲述了PHP实现驼峰样式字符串(首字母大写)转换成下划线样式字符串的方法。分享给大家供大家参考,具体如下
1、如何在php中把驼峰样式的字符串转换成下划线样式的字符串。例输入是FooBar的话,输出则是foo_bar
以下是用正则的方式去完成,既然用到正则,方法肯定就不只一种,我们看下狼蚁网站SEO优化的方式
echo strtolower(preg_replace('/(?<=[a-z])([A-Z])/', '_$1', 'fooBar')); //outputfoo_bar echo "<br>"; echo strtolower(preg_replace('/(?<=[a-z])([A-Z])/', '_$1', 'foo')); //outputfoo echo "<br>"; echo strtolower(preg_replace('/(?<=[a-z])([A-Z])/', '_$1', 'fooBarB')); //outputfoo_bar_b echo "<br>";
狼蚁网站SEO优化我们来解释下,上面正则的意思。具体正则的基本知识,这里篇幅有限就不具体介绍了,文章末尾会附带几篇的比较好的正则表达式的文章。
上面的正则里面主要用到了正则表达式中的环视边界匹配的语法。具体定义如下(摘抄)
环视的字面意思就是左右看看,需要左右符合一些条件,本质上,它也是匹配边界,对边界有一些要求,这个要求是针对左边或右边的字符串的,根据要求不同,分为四种环视
肯定顺序环视,语法是(?=...),要求右边的字符串匹配指定的表达式,比如表达式abc(?=def),(?=def)在字符c右面,即匹配c右面的边界,对这个边界的要求是,它的右边有def,比如abcdef,如果没有,比如abcd,则不匹配;
否定顺序环视,语法是(?!...),要求右边的字符串不能匹配指定的表达式,比如表达式s(?!ing),匹配一般的s,但不匹配后面有ing的s;
肯定逆序环视,语法是(?<=...),要求左边的字符串匹配指定的表达式,比如表达式(?<=\s)abc,(?<=\s)在字符a左边,即匹配a左边的边界,对这个边界的要求是,它的左边必须是空白字符;
否定逆序环视,语法是(?<!...),要求左边的字符串不能匹配指定的表达式,比如表达式(?<!\w)cat,(?<!\w)在字符c左边,即匹配c左边的边界,对这个边界的要求是,它的左边不能是单词字符。
可以看出,环视也使用括号(),不过,它不是分组,不占用分组编号。
继续回到我们上面的正则表达式,第一个小括号(?<=[a-z]),这是肯定逆序环视的语法,要求匹配的字符串的左边必须有小写的字母。第二个小括号则是一个分组,匹配大写的字母,注意正则中的分组编号是从1开始的,这和我们传统编程下标一般是从0开始不同。而第一个小括号本身就是语法,其不占用分组编号,所以后面的$1,则是匹配的第二个小括号中的内容,并将其前面添加一个_符号,再整体将整个字符串转换成小写。
既然我们已经能把驼峰法转为下划线的样式了,如果反过来又该怎办呢?
2、如何在php中把下划线样式的字符串转换成驼峰样式的字符串。例输入是foo_bar的话,输出则是FooBar
$str = preg_replace_callback('/_+([a-z])/',function($matches){ print_r($matches); //Array ( [0] => _b [1] => b ) return strtoupper($matches[1]); },'foo_bar'); echo $str; //fooBar echo "<br>"; $str = preg_replace_callback('/_+([a-z])/',function($matches){ return strtoupper($matches[1]); },'foo'); echo $str; //foo echo "<br>"; $str = preg_replace_callback('/_+([a-z])/',function($matches){ return strtoupper($matches[1]); },'foo_bar_b'); echo $str; //fooBarB echo "<br>";
这里我们用到了preg_replace_callback
函数,该函数执行一个正则表达式搜索并且使用一个回调进行替换。换言之,就是第一个参数是正则表达式,第二个参数是一个匹配到结果的回调函数,第三个参数是需要匹配的字符串。注意,回调函数具体什么时候调用,是每次匹配到结果则调用,调用次数不只为一次,匹配不到则不调用。并且该回调函数的参数是匹配的结果,是完整的匹配,matches[0]
是完整的匹配,matches[1]
是第一个捕获子组的匹配,以此类推。且回调函数需要把更改的结果return出去,不然则忽略捕获的字符串
正则表达式比较简单,这里就不具体分析了。
正则速查表
详细的正则表达式语法可参考
正则表达式30分钟入门教程
PS这里再为大家提供2款非常方便的正则表达式工具供大家参考使用
JavaScript正则表达式在线测试工具
正则表达式在线生成工具
更多关于PHP相关内容感兴趣的读者可查看本站专题《》、《》、《》、《》、《》及《》
希望本文所述对大家PHP程序设计有所帮助。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程