>백엔드 개발 >PHP 튜토리얼 >PHP의 전역 정규식 일치 및 일치 배열 요소(자세한 예)

PHP의 전역 정규식 일치 및 일치 배열 요소(자세한 예)

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB원래의
2021-11-01 11:20:155935검색

이전 글에서는 "Exciting Basics of Regular Expressions in PHP (Detailed Description with Illustrations)"을 가져왔는데, 여기서는 정규식에 대한 몇 가지 기본 지식을 간략하게 소개했습니다. 이번 글에서는 계속해서 몇 가지 일반적인 내용을 살펴보겠습니다. 정규식의 기능이 모든 사람에게 도움이 되기를 바랍니다.

PHP의 전역 정규식 일치 및 일치 배열 요소(자세한 예)

이전 글에서는 정규식의 몇 가지 기본 정의와 preg_match() 함수의 기본 적용을 소개했습니다. 정규식을 사용하는 주요 목적은 간단한 방법을 사용하여 달성하는 것입니다. 강력한 기능. 간단하고 효과적이며 강력하기 위해서는 정규식 규칙이 복잡하고 올바르고 효과적인 정규식을 구성하는 것이 더욱 어렵기 때문에 preg_match() 함수 하나만 사용하는 것만으로는 충분한 대처가 불가능합니다. . preg_match() 函数的基础应用,使用正则表达式的主要目的就是为了通过简单的办法来实现强大的功能。为了简单、有效而又不失强大,造成了正则表达式规则的复杂,构建正确、有效的正则表达式更是难度较大,所以只用一个preg_match() 函数不足以应付。

正则表达式是在处理文本数据时的一项重要而复杂的技术。而一些文本编辑器也使用正则表达式实现高级别的“搜索/替换”功能。想要实现更多的功能就需要了解更多的函数,接下来我们就来看一下,正则表达式更多的函数知识吧。

<strong><span style="font-size: 18px;">preg_match_all()</span></strong><strong><span style="font-size: 18px;"></span></strong>函数

之前我们只介绍了preg_match() 函数这一种基础函数,在 PHP 中还有一个和 preg_match() 函数极为类似的函数——preg_match_all(),该函数可以搜索字符串中所有可以和正则表达式匹配的结果。

该函数的语法格式如下:

preg_match_all($pattern, $subject [, &$matches [, $flags = PREG_PATTERN_ORDER [, $offset = 0 ]]])

其中需要注意的是:

$pattern表示要搜索的模式,也就是定义好的正则表达式;$subject表示要搜索的字符串;$matches表示可选参数是个多维数组,用来存放所有匹配的结果, 数组排序通过 $flags 指定;$offset表示可选参数,$offset 用于从目标字符串中指定位置开始搜索,它的单位是字节。

$flags表示可选参数,其中它可以结合下面几个标记使用,

  • <strong>PREG_PATTERN_ORDER</strong>

结果排序为 $matches[0] 保存完整模式的所有匹配,$matches[1] 保存第一个子组的所有匹配,以此类推。

  • <strong>PREG_SET_ORDER</strong>

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

  • <strong>PREG_OFFSET_CAPTURE</strong>

如果这个标记被传递,每个发现的匹配返回时会增加它相对目标字符串的偏移量。注意这会改变 $matches 中的每一个匹配结果字符串元素,使其成为一个第 0 个元素为匹配结果字符串,第 1 个元素为匹配结果字符串在 subject 中的偏移量。

其中不能同时使用 PREG_PATTERN_ORDER PREG_SET_ORDER,preg_match_all() 函数可以返回 $pattern 的匹配次数(可能是 0),如果发生错误则返回 FALSE

接下来我们通过示例来看一下preg_match_all() 函数的应用,匹配一个字符串,示例如下:

<?php
    $subject = "abcdefghijkdefabcedfdefxyzdef";
    $pattern_1 = &#39;/(def)(abc)/&#39;;
    $num_1 = preg_match_all($pattern_1, $subject, $matches_1,PREG_PATTERN_ORDER);
    echo "<pre class="brush:php;toolbar:false">";
    var_dump($matches_1);
    var_dump($num_1);
    $pattern_2 = &#39;/(def)(abc)/&#39;;
    $num_2 = preg_match_all($pattern_2, $subject, $matches_2,PREG_OFFSET_CAPTURE, 3);
    var_dump($matches_2);
    var_dump($num_2);
?>

输出结果:

PHP의 전역 정규식 일치 및 일치 배열 요소(자세한 예)

由上述示例中,我们便完成了通过preg_match_all() 函数来匹配一个字符串。通过preg_match_all() 函数的应用,可以完成全局正则表达式匹配。

那接下来那我们看一下怎样完成检测与给定模式匹配的数组元素。这时候就要用到preg_grep() 函数了。

<strong><span style="font-size: 18px;">preg_grep() </span></strong>정규 표현식은 텍스트 데이터를 처리할 때 중요하고 복잡한 기술입니다. 일부 텍스트 편집기에서는 정규식을 사용하여 고급 "검색/바꾸기" 기능을 구현하기도 합니다. 더 많은 기능을 구현하려면 더 많은 기능을 알아야 합니다. 다음으로 정규식에 대한 더 많은 기능 지식을 살펴보겠습니다.

preg_match_all()


🎜🎜🎜 function🎜🎜🎜🎜 앞서 preg_match() 함수의 기본 함수만 소개하기도 했습니다. preg_match() 함수 - preg_match_all()와 매우 유사한 PHP 함수입니다. 이 함수는 정규식과 일치할 수 있는 문자열의 모든 결과를 검색할 수 있습니다. . 🎜🎜이 함수의 구문 형식은 다음과 같습니다. 🎜
preg_grep($pattern, $input [, $flags = 0 ])
🎜주의해야 할 사항은 다음과 같습니다. 🎜🎜🎜$pattern은 검색할 패턴을 나타내며, 이는 정의된 정규 표현식입니다. >$subject 는 검색할 문자열을 나타냅니다. $matches는 선택적 매개변수가 일치하는 모든 결과를 저장하는 데 사용되는 다차원 배열임을 나타냅니다. 배열 정렬은 로 지정됩니다. $flags ; $offset는 선택적 매개변수를 나타내며, $offset은 대상 문자열의 지정된 위치부터 검색을 시작하는 데 사용되며 단위는 바이트입니다. 🎜🎜$flags는 다음 태그와 함께 사용할 수 있는 선택적 매개변수를 나타냅니다. 🎜
  • 🎜🎜PREG_PATTERN_ORDER🎜🎜
🎜결과는 $matches[0]가 전체 패턴의 모든 일치 항목을 저장하고 $matches[1]가 첫 번째 하위 그룹의 모든 일치 항목을 저장하는 방식으로 정렬됩니다. 🎜
  • 🎜🎜PREG_SET_ORDER🎜🎜
🎜결과는 $matches[0]으로 정렬됩니다. 한 번의 일치로 얻은 첫 번째 모든 일치(하위 그룹 포함)를 포함하여 $matches[1]는 두 번째 일치로 얻은 모든 일치(하위 그룹 포함)를 포함하는 배열입니다. 🎜
  • 🎜🎜PREG_OFFSET_CAPTURE🎜🎜
🎜이 태그가 전달되면 각각 일치하는 항목을 찾았습니다. 대상 문자열을 기준으로 오프셋이 증가되어 반환됩니다. 이렇게 하면 $matches 의 각 일치 결과 문자열 요소가 변경되어 0번째 요소가 일치 결과 문자열이고 첫 번째 요소가 제목 오프셋의 일치 결과 문자열인 일치 결과 문자열이 됩니다. . 🎜🎜 PREG_PATTERN_ORDER PREG_SET_ORDER는 동시에 사용할 수 없습니다. preg_match_all() 함수는 오류가 발생하는 경우 $pattern의 일치 수(아마도 0)를 반환할 수 있습니다. , FALSE 를 반환합니다. 🎜🎜다음으로 문자열을 일치시키는 예제를 통해 preg_match_all() 함수의 적용을 살펴보겠습니다. 🎜
<?php
    $test_arr = array(
        &#39;PHP中文网&#39;,
        &#39;http://www.php.cn/&#39;,
        &#39;php教程&#39;,
        &#39;abcdefg&#39;
    );
    $preg = &#39;/^[a-z]/&#39;;
    $preg_arr_1 = preg_grep($preg, $test_arr);
    $preg_arr_2 = preg_grep($preg, $test_arr, PREG_GREP_INVERT);
    echo &#39;<pre class="brush:php;toolbar:false">&#39;;
    var_dump($preg_arr_1);
    var_dump($preg_arr_2);
?>
🎜출력 결과: 🎜🎜PHP의 전역 정규식 일치 및 일치 배열 요소(자세한 예)🎜🎜위의 예에서 preg_match_all()을 통해 문자열 매칭을 완료했습니다. 기능. 전역 정규식 일치는 preg_match_all() 함수를 적용하여 완료할 수 있습니다. 🎜🎜그럼 주어진 패턴과 일치하는 배열 요소를 감지하는 방법을 살펴보겠습니다. preg_grep() 함수가 사용되는 경우입니다. 🎜🎜🎜🎜preg_grep() 🎜🎜🎜🎜function🎜🎜🎜🎜정규식을 사용하면 문자열뿐만 아니라 배열의 요소도 일치시킬 수 있습니다. PHP의 preg_grep() 함수는 배열의 모든 요소를 ​​검색하고 정규식과 일치하는 모든 요소의 배열을 반환할 수 있습니다. 이 함수의 구문 형식은 다음과 같습니다. 🎜rrreee🎜 주목해야 할 사항은 다음과 같습니다. 🎜🎜

$pattern表示要搜索的模式,也就是定义好的正则表达式;$input表示要搜索的数组;$flags表示可选参数,可以设置为 PREG_GREP_INVERT,这时函数会返回数组中与给定模式 $pattern 不匹配的元素组成的数组。perg_grep() 函数将遍历 $input 数组中的每一个元素,让该元素与模式 $pattern 进行匹配,然后将匹配成功或者匹配失败的元素返回。

接下来,我们通过示例来看一下使用 perg_grep() 函数匹配数组中的元素,示例如下:

<?php
    $test_arr = array(
        &#39;PHP中文网&#39;,
        &#39;http://www.php.cn/&#39;,
        &#39;php教程&#39;,
        &#39;abcdefg&#39;
    );
    $preg = &#39;/^[a-z]/&#39;;
    $preg_arr_1 = preg_grep($preg, $test_arr);
    $preg_arr_2 = preg_grep($preg, $test_arr, PREG_GREP_INVERT);
    echo &#39;<pre class="brush:php;toolbar:false">&#39;;
    var_dump($preg_arr_1);
    var_dump($preg_arr_2);
?>

输出结果:

PHP의 전역 정규식 일치 및 일치 배열 요소(자세한 예)

上述示例便是通过preg_grep() 函数匹配数组中的元素。

大家如果感兴趣的话,可以点击《PHP视频教程》、《正则表达式手册》进行更多关于PHP和正则表达式知识的学习。

위 내용은 PHP의 전역 정규식 일치 및 일치 배열 요소(자세한 예)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.