正则表达式 – 如何搜索单词或复数版本的单词[复制]

前端之家收集整理的这篇文章主要介绍了正则表达式 – 如何搜索单词或复数版本的单词[复制]前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
参见英文答案 > Regex search and replace with optional plural                                    4个
我正在尝试做一个简单的正则表达式,我想做的就是匹配一个单词的奇异部分,无论它是否有一个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的评论获取更多深度信息.

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