[python] 정규식 내에서 변수를 사용하는 방법은 무엇입니까?

variable내부 를 사용하고 싶습니다 regex. 어떻게 할 수 Python있습니까?

TEXTO = sys.argv[1]

if re.search(r"\b(?=\w)TEXTO\b(?!\w)", subject, re.IGNORECASE):
    # Successful match
else:
    # Match attempt failed



답변

python 3.6부터는 Literal String Interpolation , “f-strings”를 사용할 수 있습니다 . 특별한 경우 해결책은 다음과 같습니다.

if re.search(rf"\b(?=\w){TEXTO}\b(?!\w)", subject, re.IGNORECASE):
    ...do something

편집하다:

특수 문자를 다루는 방법에 대한 의견에 몇 가지 질문이 있었으므로 대답을 확장하고 싶습니다.

원시 문자열 ( ‘r’) :

정규 표현식에서 특수 문자를 처리 할 때 이해해야하는 주요 개념 중 하나는 문자열 리터럴과 정규 표현식 자체를 구별하는 것입니다. 여기에 잘 설명되어 있습니다 .

한마디로 :

의 대신 단어 경계를 찾는 생각한 \bTEXTO당신은 문자열과 일치 할 \boundary. 당신은 작성해야합니다 :

TEXTO = "Var"
subject = r"Var\boundary"

if re.search(rf"\b(?=\w){TEXTO}\\boundary(?!\w)", subject, re.IGNORECASE):
    print("match")

이것은 우리가 원시 문자열을 사용하기 때문에 작동합니다 (정규식 앞에 ‘r’이옵니다). 그렇지 않으면 정규식에 “\\\\ boundary”를 써야합니다 (4 개의 백 슬래시). 또한 ‘\ r’이 없으면 \ b ‘는 더 이상 단어 경계로 변환되지 않고 백 스페이스로 변환됩니다!

다시 탈출 :

기본적으로 특수 문자 앞에 백 스페이스를 넣습니다. 따라서 TEXTO에 특수 문자가 필요한 경우 다음을 작성해야합니다.

if re.search(rf"\b(?=\w){re.escape(TEXTO)}\b(?!\w)", subject, re.IGNORECASE):
    print("match")

참고 : 모든 버전의 경우> = 파이썬 3.7 : !, ", %, ', ,, /, :, ;, <, =, >, @, 및 `입니다 탈출하지. 정규 표현식에서 의미가있는 특수 문자 만 여전히 이스케이프 처리됩니다. _Python 3.3 이후로 이스케이프되지 않습니다. (s. here )

중괄호 :

f- 문자열을 사용하는 정규식 내에서 한정자를 사용하려면 이중 중괄호를 사용해야합니다. TEXTO와 정확히 두 자리 숫자를 일치시키고 싶다고 가정 해 봅시다.

if re.search(rf"\b(?=\w){re.escape(TEXTO)}\d{{2}}\b(?!\w)", subject, re.IGNORECASE):
    print("match")


답변

정규식을 문자열로 작성해야합니다.

TEXTO = sys.argv[1]
my_regex = r"\b(?=\w)" + re.escape(TEXTO) + r"\b(?!\w)"

if re.search(my_regex, subject, re.IGNORECASE):
    etc.

사용에 유의하십시오 re.escape 텍스트에 특수 문자가 포함되어 있으면, 그들은 이와 같이 해석되지 않도록합니다.


답변

if re.search(r"\b(?<=\w)%s\b(?!\w)" % TEXTO, subject, re.IGNORECASE):

이것은 TEXTO에있는 것을 정규식에 문자열로 삽입합니다.


답변

rx = r'\b(?<=\w){0}\b(?!\w)'.format(TEXTO)


답변

여러 개의 작은 패턴을 함께 묶어 정규 표현식 패턴을 작성하는 것이 매우 편리하다는 것을 알았습니다.

import re

string = "begin:id1:tag:middl:id2:tag:id3:end"
re_str1 = r'(?<=(\S{5})):'
re_str2 = r'(id\d+):(?=tag:)'
re_pattern = re.compile(re_str1 + re_str2)
match = re_pattern.findall(string)
print(match)

산출:

[('begin', 'id1'), ('middl', 'id2')]


답변

다음을 제외하고 위의 모든 사항에 동의합니다.

sys.argv[1] 같은 것 Chicken\d{2}-\d{2}An\s*important\s*anchor

sys.argv[1] = "Chicken\d{2}-\d{2}An\s*important\s*anchor"

re.escape경우 정규 표현식처럼 동작하기를 원하기 때문에을 사용하고 싶지 않습니다.

TEXTO = sys.argv[1]

if re.search(r"\b(?<=\w)" + TEXTO + "\b(?!\w)", subject, re.IGNORECASE):
    # Successful match
else:
    # Match attempt failed


답변

서로 비슷한 사용자 이름을 검색해야했으며 Ned Batchelder가 말한 내용이 매우 유용했습니다. 그러나 re.compile을 사용하여 다시 검색 용어를 만들 때 더 깨끗한 출력을 얻었습니다.

pattern = re.compile(r"("+username+".*):(.*?):(.*?):(.*?):(.*)"
matches = re.findall(pattern, lines)

다음을 사용하여 출력을 인쇄 할 수 있습니다.

print(matches[1]) # prints one whole matching line (in this case, the first line)
print(matches[1][3]) # prints the fourth character group (established with the parentheses in the regex statement) of the first line.