사전의 문자열 표현을 사전으로 변환
주어진 것과 같이 사전의 문자열 표현을 변환해야 할 수도 있습니다. 아래를 실제 사전으로 변환합니다.
s = "{'muffin' : 'lolz', 'foo' : 'kitty'}"
이러한 변환에는 eval을 사용하지 않는 것이 좋습니다. 보안 문제에. 다음은 몇 가지 더 안전한 대안입니다.
ast.literal_eval 사용:
Python의 ast 모듈은 표현식 문자열을 안전하게 평가하기 위해 특별히 설계된 literal_eval이라는 편리한 함수를 제공합니다.
import ast dict_from_string = ast.literal_eval("{'muffin' : 'lolz', 'foo' : 'kitty'}")
이 방법은 리터럴과 단순 평가만 허용합니다. 표현식을 사용하므로 eval보다 훨씬 안전합니다.
ast.literal_eval의 장점:
eval과 달리 ast.literal_eval은 제한된 Python 리터럴 집합으로 평가를 제한합니다. 임의 코드 실행과 관련된 잠재적인 보안 위험을 방지합니다.
위 내용은 사전의 문자열 표현을 Python 사전으로 안전하게 변환하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!