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

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

DDD
DDD원래의
2024-12-29 06:08:11820검색

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

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

주어진 것과 같이 사전의 문자열 표현을 변환해야 할 수도 있습니다. 아래를 실제 사전으로 변환합니다.

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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