>  기사  >  백엔드 개발  >  산술 표현식 변환을 위해 Python 정규 표현식을 사용하는 방법

산술 표현식 변환을 위해 Python 정규 표현식을 사용하는 방법

WBOY
WBOY원래의
2023-06-22 23:04:311698검색

정규식은 Python의 강력한 도구로, 텍스트 일치, 검색, 바꾸기 및 기타 작업에 사용할 수 있습니다. 컴퓨터 과학에서 정규식은 산술 표현식을 컴퓨터가 읽을 수 있는 형식으로 쉽게 구문 분석하는 데 사용됩니다. 이 기사에서는 산술식 변환을 위해 Python 정규식을 사용하는 방법을 소개합니다.

먼저, 산술 표현의 문법 규칙을 이해해야 합니다. 산술 표현식은 피연산자와 연산자로 구성됩니다(예: 2 + 4 * 5). 이 식에서 숫자 2, 4, 5는 피연산자이고 더하기 및 곱하기 기호는 연산자입니다. 산술 표현식이 구문 분석되는 순서는 연산자의 우선 순위에 따라 결정됩니다. 일반적으로 곱셈과 나눗셈이 덧셈과 뺄셈보다 우선순위가 높습니다.

이제 정규식을 사용하여 산술식을 구문 분석하는 방법을 살펴보겠습니다. 먼저, 산술 표현식과 일치하는 정규 표현식을 정의해야 합니다. 간단한 정규 표현식은 다음과 같습니다:

pattern = r"(d+)([+-*/])(d+)"

이 정규 표현식은 두 숫자와 연산자의 조합과 일치합니다. 그 중 "(d+)"는 임의 개수의 숫자가 일치한다는 의미이고, "([+-*/])"는 덧셈, 뺄셈, 곱셈, 나눗셈 연산자가 일치한다는 의미입니다.

이제 정규식을 사용하여 산술 표현식을 구문 분석하는 Python 함수를 작성해 보겠습니다.

import re

def evaluate(expression):
    pattern = r"(d+)([+-*/])(d+)"
    match = re.match(pattern, expression)
    if match:
        operand1 = int(match.group(1))
        operator = match.group(2)
        operand2 = int(match.group(3))
        if operator == "+":
            return operand1 + operand2
        elif operator == "-":
            return operand1 - operand2
        elif operator == "*":
            return operand1 * operand2
        elif operator == "/":
            return operand1 / operand2
    else:
        return None

이 함수는 산술 표현식을 매개변수로 받아들이고 계산 결과를 반환합니다. 먼저 정규식을 사용하여 표현식의 숫자와 연산자를 일치시키고 이를 변수 Operand1, Operator, Operand2에 저장합니다. 그런 다음 연산자의 유형에 따라 계산을 수행하고 결과를 반환합니다.

이제 평가 함수의 기능을 테스트해 보겠습니다.

print(evaluate("2 + 4 * 5")) # 22
print(evaluate("10 - 3 / 2")) # 8.5

결과가 모두 정확합니다. 평가 함수는 산술 표현식을 성공적으로 구문 분석하고 결과를 계산할 수 있습니다.

마지막으로 연산자 우선순위 처리 방법을 소개하겠습니다. 정규식과 재귀 함수를 사용하여 이를 수행할 수 있습니다. 먼저, 우선순위가 다른 연산자와 일치하는 여러 정규식을 정의합니다.

pattern_high = r"(d+)([*/])(d+)"
pattern_low = r"(d+)([+-])(d+)"

그중에서, 패턴_하이는 곱셈 및 나눗셈 연산과 일치하고, 패턴_로우는 덧셈 및 뺄셈 연산과 일치합니다. 다음으로 표현식의 모든 연산자를 처리하는 재귀 함수를 작성합니다.

def evaluate(expression):
    match_high = re.search(pattern_high, expression)
    match_low = re.search(pattern_low, expression)
    if match_high:
        operand1 = int(match_high.group(1))
        operator = match_high.group(2)
        operand2 = int(match_high.group(3))
        if operator == "*":
            result = operand1 * operand2
        elif operator == "/":
            result = operand1 / operand2
        new_expression = re.sub(pattern_high, str(result), expression, count=1)
        return evaluate(new_expression)
    elif match_low:
        operand1 = int(match_low.group(1))
        operator = match_low.group(2)
        operand2 = int(match_low.group(3))
        if operator == "+":
            result = operand1 + operand2
        elif operator == "-":
            result = operand1 - operand2
        new_expression = re.sub(pattern_low, str(result), expression, count=1)
        return evaluate(new_expression)
    else:
        return int(expression)

이 함수는 두 개의 정규 표현식을 사용하여 곱셈과 나눗셈 연산은 물론 덧셈과 뺄셈 연산도 일치시킵니다. 표현식에 곱셈과 나눗셈 연산이 있는 경우 곱셈과 나눗셈 연산이 먼저 계산되고 re.sub() 함수를 사용하여 원래 표현식을 결과로 대체합니다. 수식에 덧셈과 뺄셈 연산만 있는 경우 덧셈과 뺄셈 연산이 직접 계산됩니다.

이제 최적화된 평가 기능의 기능을 테스트해 보겠습니다.

print(evaluate("2 + 4 * 5")) # 22
print(evaluate("10 - 3 / 2")) # 8.5
print(evaluate("2 + 4 * 5 / 2 - 3")) # 13

결과가 모두 정확하여 최적화가 적용되었음을 나타냅니다.

요약하자면, 산술 표현식은 쉽게 구문 분석될 수 있으며 Python 정규 표현식을 사용하여 결과를 계산할 수 있습니다. 복잡한 표현식의 경우 재귀 함수와 정규 표현식을 사용하여 연산자의 우선 순위를 처리하고 알고리즘을 자동화할 수 있습니다.

위 내용은 산술 표현식 변환을 위해 Python 정규 표현식을 사용하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.