>  기사  >  백엔드 개발  >  문자열을 사전으로 변환하는 방법

문자열을 사전으로 변환하는 방법

anonymity
anonymity원래의
2019-05-25 11:20:4916277검색

실제 작업에서는 Python 문자열을 다음과 같은 사전으로 변환해야 합니다.

user_info = '{"name" : "john", "gender" : "male" , "age": 28}'

다음 사전으로 변환하고 싶습니다:

user_dict = {"name" : "john", "gender" : " 남성", "나이": 28}

문자열을 사전으로 변환하는 방법

여러 가지 방법이 있습니다:

1. json 전달 변환하려면

>>> import json
>>> user_info= '{"name" : "john", "gender" : "male", "age": 28}'
>>> user_dict = json.loads(user_info)
>>> user_dict
{u'gender': u'male', u'age': 28, u'name': u'john'}

하지만 변환에 json을 사용하면 잠재적인 문제가 있습니다.

json 구문에서는 배열이나 객체의 문자열에 큰따옴표를 사용해야 한다고 규정하고 있으므로 작은따옴표를 사용할 수 없습니다. (공식 웹사이트에는 "문자열은 0개 이상의 유니코드 문자의 시퀀스입니다."라는 설명이 있습니다. , 큰따옴표로 묶음, 백슬래시 이스케이프 사용"), 따라서 다음 변환은 잘못되었습니다:

>>> import json
>>> user_info = "{'name' : 'john', 'gender' : 'male', 'age': 28}"
# 由于字符串使用单引号,会导致运行出错
>>> user_dict = json.loads(user_info)
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "/usr/local/Cellar/python/2.7.11/Frameworks/Python.framework/Versions/2.7/lib/python2.7/json/__init__.py", line 339, in loads
    return _default_decoder.decode(s)
  File "/usr/local/Cellar/python/2.7.11/Frameworks/Python.framework/Versions/2.7/lib/python2.7/json/decoder.py", line 364, in decode
    obj, end = self.raw_decode(s, idx=_w(s, 0).end())
  File "/usr/local/Cellar/python/2.7.11/Frameworks/Python.framework/Versions/2.7/lib/python2.7/json/decoder.py", line 380, in raw_decode
    obj, end = self.scan_once(s, idx)
ValueError: Expecting property name: line 1 column 2 (char 1)

2, by eval

>>> user_info = &#39;{"name" : "john", "gender" : "male", "age": 28}&#39;
>>> user_dict = eval(user_info)
>>> user_dict
{&#39;gender&#39;: &#39;male&#39;, &#39;age&#39;: 28, &#39;name&#39;: &#39;john&#39;}
>>> user_info = "{&#39;name&#39; : &#39;john&#39;, &#39;gender&#39; : &#39;male&#39;, &#39;age&#39;: 28}"
>>> user_dict = eval(user_info)
>>> user_dict
{&#39;gender&#39;: &#39;male&#39;, &#39;age&#39;: 28, &#39;name&#39;: &#39;john&#39;}

by eval 변환의 경우 위의 변환에 json을 사용해도 문제가 없습니다. 그러나 eval을 사용할 때 다음 예와 같이 보안 문제가 있습니다.

# 让用户输入 `user_info`
>>> user_info = raw_input(&#39;input user info: &#39;)
# 输入 {"name" : "john", "gender" : "male", "age": 28},没问题
>>> user_dict = eval(user_info)
# 输入 __import__(&#39;os&#39;).system(&#39;dir&#39;),user_dict 会列出当前的目录文件!
# 再输入一些删除命令,则可以把整个目录清空了!
>>> user_dict = eval(user_info)

3 literal_eval

>>> import ast
>>> user = &#39;{"name" : "john", "gender" : "male", "age": 28}&#39;
>>> user_dict = ast.literal_eval(user)
>>> user_dict
{&#39;gender&#39;: &#39;male&#39;, &#39;age&#39;: 28, &#39;name&#39;: &#39;john&#39;}
user_info = "{&#39;name&#39; : &#39;john&#39;, &#39;gender&#39; : &#39;male&#39;, &#39;age&#39;: 28}"
>>> user_dict = ast.literal_eval(user)
>>> user_dict
{&#39;gender&#39;: &#39;male&#39;, &#39;age&#39;: 28, &#39;name&#39;: &#39;john&#39;}

을 통해 ast.literal_eval을 사용하세요. 변환을 위해 json을 사용하는 문제나 변환을 위해 eval을 사용하는 보안 문제가 없으므로 ast.literal_eval을 사용하는 것이 좋습니다.

위 내용은 문자열을 사전으로 변환하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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