正则表达式 – 使用正则表达式将空间放在驼峰大小写字符串中

前端之家收集整理的这篇文章主要介绍了正则表达式 – 使用正则表达式将空间放在驼峰大小写字符串中前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我从 add a space between two words开始提问.

要求:拆分一个驼峰案例字符串并在大写字母之前放置空格,后面跟一个小的大小写字母或者什么都不是.大写字母之间不应该出现这个空间.

例如:CSVFilesAreCoolButTXT是一个字符串我想以这种方式产生它CSV文件很酷但TXT

我开这种方式定期表达:

"LightPurple".replace(/([a-z])([A-Z])/,'$1 $2')

如果你有超过2个单词,那么你需要使用g标志来匹配它们.

"LightPurpleCar".replace(/([a-z])([A-Z])/g,'$1 $2')

如果尝试拆分像CSVFile这样的单词,那么您可能需要使用此正则表达式:

"CSVFilesAreCool".replace(/([a-zA-Z])([A-Z])([a-z])/g,'$1 $2$3')

但它仍然不符合我的要求.

var rex = /([A-Z])([A-Z])([a-z])|([a-z])([A-Z])/g;

"CSVFilesAreCoolButTXT".replace( rex,'$1$4 $2$3$5' );
// "CSV Files Are Cool But TXT"

并且

"CSVFilesAreCoolButTXTRules".replace( rex,'$1$4 $2$3$5' );    
// "CSV Files Are Cool But TXT Rules"

与正则表达式模式匹配的主题字符串的文本将替换为替换字符串’$1 $4 $2 $3 $5′,其中$1,$2等引用模式的捕获组()匹配的子字符串.

$1表示由第一个([A-Z])子模式匹配的子字符串,$3表示由第一个([a-z])子模式匹配的子字符串等.

由于交替字符|,要进行匹配,正则表达式必须匹配([AZ])([AZ])([az])子模式或([az])([AZ])子-pattern,因此如果匹配,则几个捕获组将保持不匹配.这些捕获组可以在替换字符串中引用,但它们对它没有影响 – 实际上,它们将引用空字符串.

替换字符串中的空格确保每次匹配时在主题字符串中插入空格(尾随g标记表示正则表达式引擎将查找多个匹配).

猜你在找的正则表达式相关文章