리자

[펌] 정규식 함수

· 14년 전 · 2081
함수 코드예제 코드설명
Array RegExp.exec (to be checked) var myRe=/d(b+)(d)/ig;
var myArray = myRe.exec("cdbBdbsbz");
/d(b+)(d)/ig

cdbBdbsbzⓥ

myArray.index =1 ; (처음으로 매칭되는 위치, 컴터가 늘 그렇듯 위치는 0번째부터 센다.)
myArray.input = cdbBdbsbz; (체크할 대상)
myArray[0] = dbBd;(검사에 통과한 부분)
myArray[1] = bB;(1번째 괄호에서 체크된 부분)
myArray[2] = d;(2번째 괄호에서 체크된 부분)

myRe.lastIndex =5 ; (다음번 체크를 하기위한 위치.)
myRe.ignoreCase = true; (/i 플래그 체크)
myRe.global = true; (/g 플래그 체크)
myRe.multiline = false; (/m 플래그 체크)

RegExp.$_ = cdbBdbsbz;(입력한 스트링)
RegExp.$1 = bB;(1번째 괄호에서 체크된 부분 )

boolean RegExp.test(to be checked) var myRe=/d(b+)(d)/ig;
var checked = myRe.test("cdbBdbsbz");
document.write("checked = " + checked +";<br>");
/d(b+)(d)/ig

cdbBdbsbzⓥ

실행결과: checked = true;

String RegExp.toString() var myRe=/d(b+)(d)/ig;
var str = myRe.toString();
document.write(str);
실행 결과: /d(b+)(d)/ig
String String.replace(pattern or string, to be replaced) var str = "abcdefe";
document.write(str.replace("e" , "f")); 실행 결과: abcdffe

e가 2번 있지만, 첫번째 인자가 정규식이 아니라 문자열일 경우는 첫번째 것만 바꾼다.
var str = "aba";
document.write(str.replace(/^a/ , "c")); 실행 결과: cba
var re = /(\w+)\s(\w+)/;
var str = "John Smith";
newstr = str.replace(re, "$2, $1");
document.write(newstr) 실행 결과: Smith, John

re에 의해서 찾아진 문자열 들은 re에서 ()로 표현된 순서대로 $1, $2와 같이 변수로 저장된다.
var re = /\s(?:http|https):\/\/\S*(?:\s|$)/g;
var str = "url is http://iilii.egloos.com/ !!\n";
str += "blah home: http://www.blah.co.kr";
newstr = str.replace(re, function (str,p1,offset,s) {
return "<a href='" + str + "'>" + str + "</a>";
}
).replace(/\n/, "<br>");
document.write(newstr); url is http://iilii.egloos.com/ !!
blah home: http://www.blah.co.kr

str: 찾은 문자열
p1: ()에서 검색된 1번째 문자열. 마찬가지로 p2,p3 등도 가능
offset: str을 찾은 위치
s : 원본 문자열.

Array String.match(regular expression var str = "ABCdEFgHiJKL";
var myResult = str.match(/[a-z]/g );
for(var cnt = 0 ; cnt < myResult.length; cnt++){
document.write(cnt +":" + myResult[cnt] +"<br>");
}

document.write("비교<br>");

var str = "ABCdEFgHiJKL";
var myResult = /[a-z]/g.exec(str);
for(var cnt = 0 ; cnt < myResult.length; cnt++){
document.write(cnt +":" + myResult[cnt] +"<br>");
} 실행 결과:
0:d
1:g
2:i
비교
0:d

String.match(RegExp) =>g flag가 있어도 다 찾아낸다.
RegExp.exec(String) =>g flag가 있으면, 한 개만 찾고 끝낸다.
Array String.split([separator[, limit]]) var str = "ABCdEFgHiJKL";
var myResult = str.split(/[a-z]/g , 3);
for(var cnt = 0 ; cnt < myResult.length; cnt++){
document.write(cnt +":" + myResult[cnt] +"<br>");
} 실행 결과:
0:ABC
1:EF
2:H

주어진 문자열을 separator를 기준으로 limit 만큼 자른다.<div class='small'>[이 게시물은 관리자님에 의해 2011-10-31 17:16:08 PHP & HTML에서 이동 됨]</div>
|
댓글을 작성하시려면 로그인이 필요합니다.

프로그램

+
제목 글쓴이 날짜 조회
14년 전 조회 3,067
14년 전 조회 1,168
14년 전 조회 1,405
14년 전 조회 2,281
14년 전 조회 2,683
14년 전 조회 1,744
14년 전 조회 1,881
14년 전 조회 1,209
14년 전 조회 1,516
14년 전 조회 1,526
14년 전 조회 2,264
14년 전 조회 1,573
14년 전 조회 1,239
14년 전 조회 1,326
14년 전 조회 686
14년 전 조회 1,381
14년 전 조회 1,274
14년 전 조회 1,304
14년 전 조회 1,836
14년 전 조회 2,715
14년 전 조회 1,776
14년 전 조회 1,568
14년 전 조회 1,931
14년 전 조회 1,168
14년 전 조회 1,200
14년 전 조회 1,448
14년 전 조회 1,664
14년 전 조회 1,283
14년 전 조회 1,599
14년 전 조회 2,196
14년 전 조회 1,189
14년 전 조회 1,527
14년 전 조회 1,532
14년 전 조회 1,230
14년 전 조회 1,260
14년 전 조회 1,627
14년 전 조회 2,127
14년 전 조회 2,050
14년 전 조회 1,936
14년 전 조회 1,313
14년 전 조회 1,526
14년 전 조회 1,367
14년 전 조회 1,228
14년 전 조회 2,439
14년 전 조회 1,693
14년 전 조회 1,659
14년 전 조회 1,774
14년 전 조회 1,906
14년 전 조회 1,291
14년 전 조회 2,082
14년 전 조회 4,421
14년 전 조회 2,295
14년 전 조회 2,394
14년 전 조회 1,790
14년 전 조회 2,260
14년 전 조회 1,912
14년 전 조회 1,703
14년 전 조회 1,401
14년 전 조회 1,380
14년 전 조회 1,576
14년 전 조회 1,832
14년 전 조회 6,359
14년 전 조회 1,890
14년 전 조회 1,614
14년 전 조회 1,645
14년 전 조회 1,210
14년 전 조회 1,406
14년 전 조회 2,018
14년 전 조회 1,521
14년 전 조회 1,168
14년 전 조회 1,689
14년 전 조회 1,775
14년 전 조회 2,078
14년 전 조회 1,392
14년 전 조회 4,959
14년 전 조회 1,572
14년 전 조회 1,520
14년 전 조회 1,561
14년 전 조회 1,737
14년 전 조회 1,573
14년 전 조회 1,295
14년 전 조회 1,370
14년 전 조회 1,798
14년 전 조회 1,108
14년 전 조회 1,690
14년 전 조회 1,695
14년 전 조회 1,753
14년 전 조회 4,506
14년 전 조회 1,736
14년 전 조회 1,444
14년 전 조회 1,924
14년 전 조회 2,032
14년 전 조회 1,247
14년 전 조회 2,484
14년 전 조회 2,474
14년 전 조회 2,056
14년 전 조회 1,989
14년 전 조회 1,524
14년 전 조회 2,014
14년 전 조회 1,932