[완료]정규표현식으로 Mac뽑아내는 문제..+_+;;
글쓴이: 이소희 / 작성시간: 월, 2007/09/03 - 5:32오후
정규표현식
((?:(\\d{1,2}|[a-fA-F]{1,2}){2})(?::|-*)){6}
를 이용해서 아래 리스트에서 Mac어드레스만 뽑아내려 하는데요.
위의 정규식은 아래 목록에서 잘못된 Mac까지 가져오네요 +_+;
어떻게 하면 (1),(2)만 매칭되도록 할 수 있나요?
-----------------list --------------------- 00-1A-73-68-79-D7 << (1) 00:1A:73:68:79:D7 << (2) 00:1A:73: 00 1A 73 68 79 D7 00:1A:7::00:1A:73:68:79:D768:79:D7 << 요것도 맞는거로 나오고;;;; 00:1A:777:68:79:D7 << 요것도 맞는거로 나오고 00-1A-73-68-79-D7 << 앞에 공백 있으면 틀린거로 되야 하는데, 이것도 맞다고 나오고, 00:1A:73:68:79:D7 << 뒤에 공백이 있음에도,맞는 Mac으로 나옵니다.;;;;
Forums:
허접하긴 해도 이건 안될까요..
debian-6F:/tmp# cat -E mac.txt
00-1A-73-68-79-D7$
00:1A:73:68:79:D7$
00:1A:73:$
00 1A 73 68 79 D7$
00:1A:7::00:1A:73:68:79:D768:79:D7$
00:1A:777:68:79:D7$
00-1A-73-68-79-D7 $
00:1A:73:68:79:D7 $
debian-6F:/tmp# perl ./test.pl < mac.txt
DEBUG: 00-1A-73-68-79-D7 <- passed
DEBUG: 00:1A:73:68:79:D7 <- passed
debian-6F:/tmp# more test.pl
#!/usr/bin/perl -w
# $Id$
#
while() {
if ( $_ =~ m{(^[a-z0-9]{2}[:\-][a-z0-9]{2}[:\-][a-z0-9]{2}[:\-][a-z0-9]{2}[:\-][a-z0-9]{2}[:\-][a-z0-9]{2})$}i ) {
if( $1 ) {
print "DEBUG: $1 <- passed\n";
}
}
}
행복하세요 ^_^
행복하세요 ^_^
egrep "^([0-9a-fA-F][0-9a-fA-F]:){5}.[0-9a-fA-F]$" list
[root@log etc]# cat list
00-1A-73-68-79-D7
00:1A:73:68:79:D7
00:1A:73:
00 1A 73 68 79 D7
00:1A:7::00:1A:73:68:79:D768:79:D7
00:1A:777:68:79:D7
00-1A-73-68-79-D7
00:1A:73:68:79:D7
00:1A:73:68:79:D7A
00:1A:73:68:79:
00:1A:73:68:
[root@log etc]# egrep "^([0-9a-fA-F][0-9a-fA-F]:){5}.[0-9a-fA-F]$" list
00:E0:4C:C5:1A:38
00:1A:73:68:79:D7
--
시작은 ^, 끝은 $로 표시하면될것같습니다~
맥주소는 대충..
^"00:" x 5개 + "D7" 형식1개$
정말 감사드립니다.^____^
도움주셔서 해결 됐습니다.
^____^
좋은밤 되세요~!
^([0-9a-fA-F][0-9a-fA-F](?::|-*)){5}.[0-9a-fA-F]$
내 삶속에 던져진 나.
인용:^([0-9a-fA-F][0-9a-fA-
여기서는 볼 때 Non-Capturing Parentheses 는 명료성만 떨어뜨리는 것 같습니다.
그리고 일관되게 사용하지도 않았고요.
정도면 충분할 것 같습니다.
grep에서 대소문자 구분을 무시하고
이렇게 해 보세요.
-----
익명으로 쓴 글은 볼 수 없습니다.
-----
http://monpetit.posterous.com/
http://monpetit.tistory.com/
답변 감사드립니다. ^^ 좋은 하루 되세요~!
내 삶속에 던져진 나.
내 삶속에 던져진 나.
댓글 달기