ホームページ > バックエンド開発 > PHPチュートリアル > 正则表达式 - 一句php解析html页面的脚本问题

正则表达式 - 一句php解析html页面的脚本问题

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
リリース: 2016-06-06 20:48:34
オリジナル
1177 人が閲覧しました

preg_match_all('/<td width="20%" align="left">.*<\/td>/u',$html,$match,PREG_OFFSET_CAPTURE);
ログイン後にコピー
ログイン後にコピー

主要是其中的正则表达式没看明白,开头的/和结尾的/u是代表其中的内容是unicode么?不需要用\转译这两个/

然后PREG_OFFSET_CAPTURE这个flag到底又什么用,看了文档还是没怎么明白,希望各位大大指教

回复内容:

preg_match_all('/<td width="20%" align="left">.*<\/td>/u',$html,$match,PREG_OFFSET_CAPTURE);
ログイン後にコピー
ログイン後にコピー

主要是其中的正则表达式没看明白,开头的/和结尾的/u是代表其中的内容是unicode么?不需要用\转译这两个/

然后PREG_OFFSET_CAPTURE这个flag到底又什么用,看了文档还是没怎么明白,希望各位大大指教

/ / 是表示中间内容是表达式。 u 是修饰符,定义这个模式字符串被认为是utf-8的。

http://www.php.net/manual/zh/reference.pcre.pattern.modifiers.php

嗯,//标示正则表达式开始结束,u是修饰符,具体可见 http://www.php.net/manual/zh/reference.pcre.pattern.modifiers.php

Flag结果排序方式,结合实际测试可以更清楚。

PREGPATTERNORDER 结果排序为$matches[0]保存完整的所有匹配, $matches[1] 保存第一个()的所有匹配,以此类推

PREGSETORDER 结果排序为$matches[0]包含第一次匹配得到的所有匹配(包含子组), $matches[1]是包含第二次匹配到的所有匹配(包含子组)的数组,以此类推。

関連ラベル:
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
PHP 拡張子 intl
から 1970-01-01 08:00:00
0
0
0
phpのデータ取得?
から 1970-01-01 08:00:00
0
0
0
PHP GET エラー レポート
から 1970-01-01 08:00:00
0
0
0
phpを上手に学ぶ方法
から 1970-01-01 08:00:00
0
0
0
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート