我从
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,因此如果匹配,则几个捕获组将保持不匹配.这些捕获组可以在替换字符串中引用,但它们对它没有影响 – 实际上,它们将引用空字符串.