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’) :
정규 표현식에서 특수 문자를 처리 할 때 이해해야하는 주요 개념 중 하나는 문자열 리터럴과 정규 표현식 자체를 구별하는 것입니다. 여기에 잘 설명되어 있습니다 .
한마디로 :
의 대신 단어 경계를 찾는 생각한 \b
후 TEXTO
당신은 문자열과 일치 할 \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.