php 执行正则表达式,PHP preg_match()执行匹配正则表达式

preg_match()执行匹配正则表达式

说明

preg_match ( string $pattern , string $subject [, array &$matches [, int $flags = 0 [, int $offset = 0 ]]] ) : int

搜索subject与pattern给定的正则表达式的一个匹配.

参数

pattern

要搜索的模式,字符串类型。

subject

输入字符串。

matches

如果提供了参数matches,它将被填充为搜索结果。 $matches[0]将包含完整模式匹配到的文本, $matches[1] 将包含第一个捕获子组匹配到的文本,以此类推。

flags(示例五)

flags可以被设置为以下标记值:

PREG_OFFSET_CAPTURE

如果传递了这个标记,对于每一个出现的匹配返回时会附加字符串偏移量(相对于目标字符串的)。 注意:这会改变填充到matches参数的数组,使其每个元素成为一个由 第0个元素是匹配到的字符串,第1个元素是该匹配字符串 在目标字符串subject中的偏移量。

offset(示例六)

通常,搜索从目标字符串的开始位置开始。可选参数 offset 用于 指定从目标字符串的某个位置开始搜索(单位是字节)。

返回值

preg_match()返回 pattern 的匹配次数。 它的值将是0次(不匹配)或1次,因为preg_match()在第一次匹配后 将会停止搜索。preg_match_all()不同于此,它会一直搜索subject 直到到达结尾。 如果发生错误preg_match()返回 FALSE。

示例一:查找文本字符串"php"

//模式分隔符后的"i"标记这是一个大小写不敏感的搜索

if (preg_match("/php/i", "PHP is the web scripting language of choice.")) {

echo "匹配";

} else {

echo "不匹配";

}

// 匹配

?>

示例二:查找单词"web"

/* 模式中的\b标记一个单词边界,所以只有独立的单词"web"会被匹配,而不会匹配单词的部分内容比如"webbing" 或 "cobweb" */

if (preg_match("/\bweb\b/i", "PHP is the web scripting language of choice.")) {

echo "匹配";

} else {

echo "不匹配";

}

echo '


';

if (preg_match("/\bweb\b/i", "PHP is the website scripting language of choice.")) {

echo "匹配";

} else {

echo "不匹配";

}

?>

示例三:获取URL中的域名

//从URL中获取主机名称

preg_match('@^(?:http://)?([^/]+)@i',"http://www.php.net/index.html", $matches);

$host = $matches[1];

echo $host . '
'; // www.php.net

//获取主机名称的后面两部分

preg_match('/[^.]+\.[^.]+$/', $host, $matches);

echo "域名: {$matches[0]}"; // 域名: php.net

?>

示例四:使用命名子组

$str = 'foobar: 2008';

preg_match('/(?P\w+): (?P\d+)/', $str, $matches);

/* 下面例子在php 5.2.2(pcre 7.0)或更新版本下工作, 然而, 为了后向兼容, 上面的方式是推荐写法. */

// preg_match('/(?\w+): (?\d+)/', $str, $matches);

var_dump($matches);

// array (size=5)

// 0 => string 'foobar: 2008' (length=12)

// 'name' => string 'foobar' (length=6)

// 1 => string 'foobar' (length=6)

// 'digit' => string '2008' (length=4)

// 2 => string '2008' (length=4)

?>

示例五:flags可以被设置为以下标记值:PREG_OFFSET_CAPTURE

preg_match('/(foo)(bar)(baz)/', 'foobarbaz', $matches, PREG_OFFSET_CAPTURE);

var_dump($matches);

// array (size=4)

// 0 =>

// array (size=2)

// 0 => string 'foobarbaz' (length=9)

// 1 => int 0

// 1 =>

// array (size=2)

// 0 => string 'foo' (length=3)

// 1 => int 0

// 2 =>

// array (size=2)

// 0 => string 'bar' (length=3)

// 1 => int 3

// 3 =>

// array (size=2)

// 0 => string 'baz' (length=3)

// 1 => int 6

echo '
对比没有参数PREG_OFFSET_CAPTURE
';

preg_match('/(foo)(bar)(baz)/', 'foobarbaz', $matches);

var_dump($matches);

// array (size=4)

// 0 => string 'foobarbaz' (length=9)

// 1 => string 'foo' (length=3)

// 2 => string 'bar' (length=3)

// 3 => string 'baz' (length=3)

?>

示例六:可选参数 offset 用于 指定从目标字符串的某个位置开始搜索

$subject = "abcdef";

$pattern = '/def/';

preg_match($pattern, $subject, $matches, PREG_OFFSET_CAPTURE, 4); // 从字符串位置4开始匹配,即从e开始。注释:字符串位置从 0 开始,不是从 1 开始。

print_r($matches);

// Array ( )

echo '
对比没有设置offset参数
';

preg_match($pattern, $subject, $matches, PREG_OFFSET_CAPTURE);

print_r($matches);

// Array ( [0] => Array ( [0] => def [1] => 3 ) )

?>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值