使用最后出现的点、冒号或下划线拆分字符串的正则表达式 [英] Regex to split string with the last occurrence of a dot, colon or underscore

查看:16
本文介绍了使用最后出现的点、冒号或下划线拆分字符串的正则表达式的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我们有数千行数据,其中包含各种格式的文章枚举,我需要将主要文章编号从大小指示器中分离出来。在一些最后的字符之间(几乎)总是有点、破折号或下划线(不总是2)。

简而言之:数据为主文编号+大小指标,分隔符不同,只有1/3。-_

问题:如何拆分正文编号+大小指标?我的下面的正则表达式不能正常工作,这是我基于某个Google-ing构建的。

preg_match('/^(.*)[.-_]([^.-_]+)$/', $sku, $matches);

样本数据+预期结果

AR.110052.15-40 [AR.110052.15 & 40]
BI.533.41-41 [BI.533.41 & 41]
CG.00554.000-39 [CG.00554.000 & 39]
LL.PX00.SC004-40 [LL.PX00.SC004 & 40]
LOS.HAPPYSOCKS.1X [LOS.HAPPYSOCKS & 1X]
MI.PMNH300043-XXXXL [MI.PMNH300043 & XXXXL]

推荐答案

您需要将-移到Character类的末尾,以使正则表达式引擎将其解析为文字连字符:

^(.*)[._-]([^._-]+)$

请参阅regex demo。实际上,即使^(.+)[._-](.+)$也可以。

  • ^-匹配字符串的开头
  • (.*)-组1捕获任意0+个字符,直到最后一个.
  • [._-]-._-
  • ([^._-]+)-组2:._-以外的一个或多个字符
  • $-字符串结尾。

这篇关于使用最后出现的点、冒号或下划线拆分字符串的正则表达式的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆