캡처 한 그룹 만 바꾸는 방법?
문자열 전후에 HTML 코드가 있습니다.
name="some_text_0_some_text"
나는 다음과 같이 대체하고 0
싶다 :!NEW_ID!
그래서 간단한 정규식을 만들었습니다.
.*name="\w+(\d+)\w+".*
그러나 독점적으로 캡처 된 블록을 바꾸는 방법을 모르겠습니다.
($ 1)과 같은 캡처 결과를 다른 문자열로 바꾸는 방법이 있습니까?
결과는 다음과 같습니다.
name="some_text_!NEW_ID!_some_text"
해결책은 이전 및 다음 텍스트에 대한 캡처를 추가하는 것입니다.
str.replace(/(.*name="\w+)(\d+)(\w+".*)/, "$1!NEW_ID!$3")
새로운 환경에서 Javascript는 ( ES2018 기준 ) 뒤쳐 졌으므로 이러한 상황에서 그룹을 완전히 피할 수 있습니다. 오히려, lookbehind 당신이 캡처 된 그룹 전에오고, 내다보기 위해 후 제공하고 교체하는 것에 대해 단지 !NEW_ID!
:
const str = 'name="some_text_0_some_text"';
console.log(
str.replace(/(?<=name="\w+)\d+(?=\w+")/, '!NEW_ID!')
);
이 방법을 사용하면 전체 일치 항목 만 교체해야합니다.
(?<=name="\w+)
-Lookbehind forname"
다음에 단어 문자가 있습니다 ( 행운 적으로 lookbehinds는 Javascript에서 고정 너비 일 필요는 없습니다!).\d+
-하나 이상의 숫자와 일치-패턴의 유일한 부분은 둘러보기에없고 문자열의 유일한 부분은 결과와 일치합니다.(?=\w+")
-단어 문자에 대한 Lookahead 다음에"
`
뒤돌아보기는 새로운 것임을 명심하십시오. 최신 버전의 V8 (Chrome, Opera 및 Node 포함)에서는 작동하지만 다른 환경 에서는 아직까지는 그렇지 않습니다. 따라서 Node 및 자체 브라우저에서 lookbehind를 안정적으로 사용할 수 있지만 (최신 버전의 V8에서 실행되는 경우) 공용 클라이언트와 같이 임의의 클라이언트에서 아직 충분히 지원되지 않습니다.
Matthew의 대답에 약간의 개선은 마지막 캡처 그룹 대신에 예견 일 수 있습니다.
.replace(/(\w+)(\d+)(?=\w+)/, "$1!NEW_ID!");
또는 십진수로 나누고 다음과 같이 새 ID와 결합 할 수 있습니다.
.split(/\d+/).join("!NEW_ID!");
예 / 벤치 마크 : https://codepen.io/jogai/full/oyNXBX
더 간단한 옵션은 숫자를 캡처하여 바꾸는 것입니다.
const name = 'preceding_text_0_following_text';
const matcher = /(\d+)/;
// Replace with whatever you would like
const newName = name.replace(matcher, 'NEW_STUFF');
console.log("Full replace", newName);
// Perform work on the match and replace using a function
// In this case increment it using an arrow function
const incrementedName = name.replace(matcher, (match) => ++match);
console.log("Increment", incrementedName);
자원
캡처 그룹 두 개도 가능했을 것입니다. 또한 숫자 전후에 추가 왼쪽과 오른쪽 경계로 두 개의 대시를 포함 시켰으며 수정 된 표현식은 다음과 같습니다.
(.*name=".+_)\d+(_[^"]+".*)
const regex = /(.*name=".+_)\d+(_[^"]+".*)/g;
const str = `some_data_before name="some_text_0_some_text" and then some_data after`;
const subst = `$1!NEW_ID!$2`;
const result = str.replace(regex, subst);
console.log(result);
표현식을 탐색 / 간단 화 / 수정하려는 경우 regex101.com의 오른쪽 상단에 설명되어 있습니다. 원하는 경우이 링크 에서 일부 샘플 입력과 어떻게 일치하는지 확인할 수도 있습니다.
정규식 회로
jex.im visualizes regular expressions:
참고URL : https://stackoverflow.com/questions/3954927/how-to-replace-captured-groups-only
'Programing' 카테고리의 다른 글
Fragment와 FragmentActivity의 차이점은 무엇입니까? (0) | 2020.06.07 |
---|---|
원본을 참조하면서 JavaScript 함수 재정의 (0) | 2020.06.07 |
슬래시를 이스케이프 처리하는 json_encode () (0) | 2020.06.07 |
루비에서 안전한 정수 파싱 (0) | 2020.06.07 |
C ++의 스택, 정적 및 힙 (0) | 2020.06.07 |