参见英文答案 >
Regex search and replace with optional plural 4个
我正在尝试做一个简单的正则表达式,我想做的就是匹配一个单词的奇异部分,无论它是否有一个s结尾.所以,如果我有以下的话
我正在尝试做一个简单的正则表达式,我想做的就是匹配一个单词的奇异部分,无论它是否有一个s结尾.所以,如果我有以下的话
test tests
编辑:进一步的例子,我需要这个可能很多单词而不仅仅是那两个
movie movies page pages time times
对于所有这些我需要在没有结束的情况下得到单词,但是我找不到一个正则表达式,它总是会抓住第一位而没有结尾的s并且适用于两种情况.
我尝试过以下方法:
([a-zA-Z]+)([s\b]{0,}) - This returns the full word as the first match in both cases ([a-zA-Z]+?)([s\b]{0,}) - This returns 3 different matching groups for both words ([a-zA-Z]+)([s]?) - This returns the full word as the first match in both cases ([a-zA-Z]+)(s\b) - This works for tests but doesn't match test at all ([a-zA-Z]+)(s\b)? - This returns the full word as the first match in both cases
我一直在使用http://gskinner.com/RegExr/试用不同的正则表达式.
编辑:这是一个崇高的文本片段,对于那些不知道崇高文本片段的人是一个快捷方式,以便我可以键入说我的数据库的名称并点击“运行片段”,它会把它变成一些东西喜欢:
$movies= $this->ci->db->get_where("movies",""); if ($movies->num_rows()) { foreach ($movies->result() AS $movie) { } }
我只需要将“电影”变成“电影”并自动将其插入到foreach循环中.
这意味着我不能只对文本进行查找和替换,我只需要考虑60-70个单词(它只针对我自己的表,而不是英语中的每个单词).
谢谢!
– 蒂姆
解决方法
好的,我找到了一个解决方案:
([a-zA-Z]+?)(s\b|\b)
根据需要工作,然后你可以简单地使用第一个匹配作为单词的无法使用的版本.
谢谢@Jahroy帮助我找到它.我添加了这个作为未来冲浪者的答案,他们只想要一个解决方案,但请查看Jahroy的评论以获取更多深度信息.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。