다른 언어의 정규 표현식 동작: Go와 Python
Go에서 정규 표현식을 사용하려고 할 때 개발자는 예상치 못한 동작에 직면할 수 있습니다. 예를 들어 다음 코드를 고려해 보세요.
package main import ( "fmt" "regexp" ) func main() { a := "parameter=0xFF" regex := "^.+=\b0x[A-F][A-F]\b$" result, err := regexp.MatchString(regex, a) fmt.Println(result, err) // Prints: false <nil> }
이 코드는 Python에서 올바르게 작동함에도 불구하고 예상 입력 문자열과 일치하지 않습니다.
import re p = re.compile(r"^.+=\b0x[A-F][A-F]\b$") m = p.match("parameter=0xFF") if m is not None: print(m.group()) # Prints: parameter=0xFF
이 불일치의 근본 원인은 다음과 같습니다. Go와 Python의 문자열 리터럴 간의 차이점 Go에서 문자열 리터럴은 기본적으로 "요리된" 것으로 간주됩니다. 즉, 이스케이프 시퀀스와 같은 특수 문자로 해석된다는 의미입니다. 그러나 정규 표현식의 경우 이 동작은 문제가 있습니다.
이 문제를 해결하기 위해 Go는 원시 문자열 리터럴을 제공합니다. 원시 문자열 리터럴은 따옴표(") 대신 역따옴표(`)로 묶입니다. 특수 문자나 이스케이프 시퀀스를 무시하여 리터럴이 작성된 대로 정확하게 해석되도록 합니다.
따라서 문제를 해결하려면 Go 코드에서 정규식은 원시 문자열 리터럴로 지정되어야 합니다.
var regex = `^.+=\b0x[A-F][A-F]\b$`
이 수정을 통해 코드는 이제 입력 문자열과 올바르게 일치하고 원하는 결과를 생성합니다. 결과입니다.
위 내용은 Go와 Python 정규 표현식이 다른 결과를 생성하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!