28

我有一个字符串(来自文件):

ILX (New for 2013!)

Overview: The least expensive route to Honda's premium-label goodness

Drivetrain: Two four-cylinder engines to choose from as well as a gas-electric hybrid; front-wheel-drive only.

我如何得到字符串:

$writeup = file_get_contents($car_files_path . $manufacture . '/Stories/'.$story);

我想匹配概述行(Overview: The least expensive route to Honda's premium-label goodness)。实现这一目标的最佳方法是什么。

我尝试了 .*\n,但这将匹配所有内容,然后是一个新行。有没有办法让正则表达式不贪婪?

我试过了: preg_match('/^Overview:\s.*$/im', $writeup, $overall_matches)我没有得到任何匹配

4

1 回答 1

46

在量词之后添加?使其不贪婪。在这种情况下,您的正则表达式将是.*?\n.

要专门匹配以“Overview:”开头的行,请使用此正则表达式:

/^Overview:\s.*$/im

m修饰符允许^并匹配行的$开头和结尾,而不是整个搜索字符串。请注意,没有必要让它变得不贪婪,因为.除非你使用修饰符,否则它不会匹配换行符s- 事实上,在这里让它变得不贪婪会对性能不利。

于 2013-02-19T21:13:44.477 回答