[(완료)정규표현식]
글쓴이: mattkjeon / 작성시간: 월, 2011/02/14 - 1:04오후
안녕하세요?
/dev/sda1과 같은 문자열을 입력으로 받아 처리하려고 아래와 같이 정규표현식을 만들었습니다.
char reg[] = "/block/sd[a-z]\?[1-9]\?$";
즉 sda, sda1, sdb, sdb1 과 같은 문자열을 탐지하기 위해서죠.
그런데 /block/sda 같은 것은 결과가 match라고 나오는데,
/block/sda1 과 같은 것은 non-match라고 나옵니다.
[a-z]\?[1-9]\? 이 부분에서 따옴표로 둘러싸인 두 문자 즉 /block/sd"a1" 부분을 한번에 match할 수 있는 표현이 틀린 것 같은데,
잘 모르겠네요... 아시는 분의 도움을 요청합니다.
Forums:
/block/sd[a-z]?[1-9]?$ 위와
/block/sd[a-z]?[1-9]?$
위와 같이 표현하면 잘 되는군요~
\? <-- 요 부분이 잘못된 듯 합니다.
정규식에서 특수문자 앞에 '\' 을 쓰면
일반문자로 표현됩니다.
[a-z]? <-- 이 부분이 없는 것도 혹시 있을까요?
(머리가 나빠서..;;)
없다면 [a-z] 로 쓰시는게 좋을듯 싶습니다. :)
**********************
세상의 중심 kucuny.com
**********************
먼저 답변 감사합니다. ;-)
먼저 답변 감사합니다. ;-)
답을 찾았습니다. 코드를 자세히 보지않아......
엉뚱한 곳에 문제가 있었습니다. ;-)
음 ..
char regPattern[] = "/block/sd[a-z][1-9]?$";
의 마지막 문자 $ 는 주어진 문자열이 null string 으로 끝나는 경우를 뜻합니다.
그래서 /block/sdb 또는 /block/sdb1 로 끝나는 문자열은 매칭되지만...
/block/sdb/sdb1 로 끝나는 문자열은 매칭되지 않습니다.
코드 및 결과 모두 맞게 동작하고 있습니다.
되면 한다! / feel no sorrow, feel no pain, feel no hurt, there's nothing gained.. only love will then remain.. 『 Mizz 』
고맙습니다 (내용없음)
.
댓글 달기