정규 표현식

· 11년 전 · 2305 · 1
정규 표현식은 웹 프로그래밍을 할 때 문자열을 정교하게 처리하기 위해 필요합니다.

먼저, 정규 표현식에서 사용되는 패턴 문자 몇 가지를 소개하면 아래와 같습니다.


+ -> '+' 표시 바로 앞의 문자열(문자)이 한 번 이상 존재하는 것을 의미함

^ -> '^' 표시 뒤의 문자열(문자)로 시작되는 것을 의미함

[ ] -> '[ ]' 로 둘러쌓인 문자열(문자) 중에서 하나의 문자를 의미함

[^ ] -> '[ ]' 패턴의 문자열(문자)을 제외한 나머지 문자열(문자)을 의미함

{ } -> '{ }' 앞의 문자열(문자)이 '{ }' 안의 숫자가 나타내는 갯수만큼 존재하는 것을 의미함


[[:digit:]] -> 하나의 숫자(0 에서 9 까지) 를 의미함

[[:alpha:]] -> 하나의 영문자(a 에서 Z 까지) 를 의미함

[[:alnum:]] -> 하나의 숫자(0 에서 9 까지) 또는 영문자(a 에서 Z 까지) 를 의미함

[[:space:]] -> 하나의 공백 문자(blank) 를 의미함


위 패턴 문자를 사용한 정규 표현식이 어떻게 사용되는지 살펴보기 전에, 위와 같은 패턴 문자로 나타내어진 정규 표현식을 사용하기 위해 필요한 함수가 있는데, ereg() 함수가 있습니다.

ereg() 함수는 일반적으로 두 개의 인자를 취하는데, 첫 번째 인자는 패턴 문자로 나타내어진 정규 표현식이 오며 두 번째 인자는 그 정규 표현식에 의해 검색될 대상 문자열이 옵니다.

이렇게 ereg() 함수 내의 두 번째 인자인 검색 대상 문자열에서 첫 번째 인자인 정규 표현식의 패턴이 존재할 경우 ereg() 함수는 true 값을 반환하며 그렇지 않을 경우에는 false 값을 반환하게 됩니다.

그럼, ereg() 함수를 사용하여 위 패턴 문자로 나타내어진 정규 표현식이 어떻게 사용되는지 몇 가지 예제를 살펴보겠습니다.

<?
$string = "mizzle PHP 2002";

# '+' 패턴 검사

if(ereg("iz+", $string)) {
  echo("지정된 패턴과 일치합니다.<br>"); # 실행 라인
} else {
  echo("지정된 패턴과 일치하지 않습니다.<br>");
}

# '^' 패턴 검사

if(ereg("^mi", $string)) {
  echo("지정된 패턴과 일치합니다.<br>"); # 실행 라인
} else {
  echo("지정된 패턴과 일치하지 않습니다.<br>");
}

# '[ ]' 패턴 검사

if(ereg("[si]m", $string)) {
  echo("지정된 패턴과 일치합니다.<br>");
} else {
  echo("지정된 패턴과 일치하지 않습니다.<br>"); # 실행 라인
}

# '[[:digit:]]' 패턴 검사

if(ereg("[[:digit:]]{4}", $string)) {
  echo("지정된 패턴과 일치합니다.<br>"); # 실행 라인
} else {
  echo("지정된 패턴과 일치하지 않습니다.<br>");
}

# '[[:alpha]]' 패턴 검사

if(ereg("[[:alpha:]]{7}", $string)) {
  echo("지정된 패턴과 일치합니다.<br>");
} else {
  echo("지정된 패턴과 일치하지 않습니다.<br>"); # 실행 라인
}

# '[[:space]]' 패턴 검사

if(ereg("[[:space:]]{2}", $string)) {
  echo("지정된 패턴과 일치합니다.<br>");
} else {
  echo("지정된 패턴과 일치하지 않습니다.<br>"); # 실행 라인
}
?>

위 예제를 실행하게 되면, 위 예제 코드의 주석("#실행 라인")으로 표기한 라인이 실행되는 것을 볼 수 있습니다.

위 예제 중 몇 가지만 살펴보면,

'+' 패턴 검사 코드의 경우, "iz" 문자열이 한 번 이상 존재해야 함을 의미하는 iz+ 패턴이 "mizzle PHP 2002" 문자열에 존재하기 때문에 비교 조건식에 일치하는 결과가 출력됩니다.

'[ ]' 패턴 검사 코드의 경우, "sm" 또는 "im" 문자열이 존재해야 함을 의미하는 [si]m 패턴이 "mizzle PHP 2002" 문자열에 존재하지 않기 때문에 비교 조건식에 일치하지 않는 결과가 출력됩니다.

'[[:digit:]]' 패턴 검사 코드의 경우, 연속되는 숫자 4개의 문자가 존재해야 함을 의미하는 [[:digit:]]{4} 패턴이 "mizzle PHP 2002" 문자열에 존재하기 때문에 비교 조건식에 일치하는 결과가 출력됩니다.

이상, 정규 표현식의 기초에 대해서 살펴보았습니다.
|

댓글 1개

http://regex101.com/ 와 같은 정규표현식 테스트터를 이용해 확인하면서 작업하시면 더욱 편리합니다~
댓글을 작성하시려면 로그인이 필요합니다.

프로그램

+
제목 글쓴이 날짜 조회
11년 전 조회 2,409
11년 전 조회 3,268
11년 전 조회 2,309
11년 전 조회 2,377
11년 전 조회 4,022
11년 전 조회 3,710
11년 전 조회 2,586
11년 전 조회 3,121
11년 전 조회 2,632
11년 전 조회 2,566
11년 전 조회 2,760
11년 전 조회 3,312
11년 전 조회 2,301
11년 전 조회 3,378
11년 전 조회 3,626
11년 전 조회 2,297
11년 전 조회 2,408
11년 전 조회 2,146
11년 전 조회 3,090
11년 전 조회 2,997
11년 전 조회 2,465
11년 전 조회 2,348
11년 전 조회 2,099
11년 전 조회 2,535
11년 전 조회 2,936
11년 전 조회 1,999
11년 전 조회 2,184
11년 전 조회 2,330
11년 전 조회 2,321
11년 전 조회 2,525
11년 전 조회 4,040
11년 전 조회 3,729
11년 전 조회 3,164
11년 전 조회 2,848
11년 전 조회 2,769
11년 전 조회 3,776
11년 전 조회 3,001
11년 전 조회 4,199
11년 전 조회 5,038
11년 전 조회 5,168
11년 전 조회 5,220
11년 전 조회 5,366
11년 전 조회 3,840
11년 전 조회 1.9만
11년 전 조회 2,792
11년 전 조회 2,520
11년 전 조회 2,517
11년 전 조회 2,291
11년 전 조회 2,451
11년 전 조회 2,306
11년 전 조회 2,083
11년 전 조회 2,523
11년 전 조회 2,224
11년 전 조회 2,165
11년 전 조회 2,431
11년 전 조회 2,344
11년 전 조회 2,135
11년 전 조회 2,295
11년 전 조회 2,300
11년 전 조회 2,298
11년 전 조회 2,420
11년 전 조회 2,005
11년 전 조회 2,087
11년 전 조회 2,253
11년 전 조회 2,117
11년 전 조회 2,172
11년 전 조회 2,090
11년 전 조회 2,037
11년 전 조회 2,120
11년 전 조회 2,759
11년 전 조회 2,073
11년 전 조회 2,389
11년 전 조회 2,266
11년 전 조회 2,028
11년 전 조회 2,046
11년 전 조회 2,141
11년 전 조회 2,087
11년 전 조회 2,679
11년 전 조회 5,573
11년 전 조회 2,643
11년 전 조회 2,364
11년 전 조회 2,802
11년 전 조회 8,990
11년 전 조회 2,554
11년 전 조회 3,771
11년 전 조회 2,578
11년 전 조회 2,524
11년 전 조회 2,824
11년 전 조회 2,314
11년 전 조회 2,305
11년 전 조회 2,294
11년 전 조회 2,355
11년 전 조회 2,970
11년 전 조회 2,366
11년 전 조회 2,626
11년 전 조회 2,411
11년 전 조회 6,118
11년 전 조회 2,127
11년 전 조회 2,551
11년 전 조회 2,915