>백엔드 개발 >파이썬 튜토리얼 >Python에서 사전의 문자열 표현을 사전으로 안전하게 변환하려면 어떻게 해야 합니까?

Python에서 사전의 문자열 표현을 사전으로 안전하게 변환하려면 어떻게 해야 합니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-12-23 12:11:19453검색

How Can I Safely Convert a String Representation of a Dictionary to a Dictionary in Python?

사전의 문자열 표현을 사전으로 변환

Python에서는 아래 문자열 표현과 같이 사전의 문자열 표현을 변환하는 것이 종종 바람직합니다. , 해당하는 사전:

s = "{'muffin' : 'lolz', 'foo' : 'kitty'}"

'eval' 사용 피하기

'eval' 함수를 사용하여 문자열 표현식을 평가하는 것이 가능하지만 이 방법은 다음과 같은 이유로 권장되지 않습니다. 보안 문제. 'eval'은 임의의 코드를 실행하여 취약점의 위험을 높입니다.

더 안전한 대안

문자열 사전을 안전하게 변환하려면 내장된 'ast.literal_eval' 사용을 고려하세요. ' 기능. 'ast.literal_eval'은 사전, 튜플, 목록 등의 문자열 표현과 같은 리터럴 Python 표현식을 평가하도록 특별히 설계되었습니다.

import ast
ast.literal_eval("{'muffin' : 'lolz', 'foo' : 'kitty'}")

출력:

{'muffin': 'lolz', 'foo': 'kitty'}

이점 'ast.literal_eval'

  • 안전성: 리터럴 표현식만 평가하여 악성 코드 실행을 방지합니다.
  • 다용성: 사전뿐만 아니라 목록, 튜플, 및 기타 Python 리터럴 구조.

'eval'과 비교하면, 'ast.literal_eval'은 사전이나 기타 리터럴의 문자열 표현을 Python 객체로 변환하는 더 안전하고 제어된 방법을 제공합니다.

위 내용은 Python에서 사전의 문자열 표현을 사전으로 안전하게 변환하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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