python如何将字符串转换成json的几种办法

python如何将字符串转换成json的几种办法

  • 最近在工作中遇到了一个小问题,如果要将字符串型的数据转换成dict类型,我第一时间就想到了使用json函数。但是里面出现了一些问题

1、通过json来转换:

In [1]: import json

In [2]: mes = ‘{"InsId": 2, "name": "lege-happy", "CreationTime": "2019-04-23T03:18:02Z"}‘

In [3]: mes_to_dict = json.loads(mes)

In [4]: print type(mes_to_dict)
<type ‘dict‘>
  • 以上的方式转换是没问题的,但是加入mes的格式为mes = ‘{"InsId": 2, "name": "lege-happy", "CreationTime": "2019-04-23T03:18:02Z"}‘的时候使用json来转换的时候又会发生什么呢?
In [5]: import json

In [6]: mes = "{‘InsId‘: 1, ‘name‘: ‘lege-error‘, ‘CreationTime‘: ‘2019-04-24T03:18:02Z‘}"

In [7]: mes_to_dict = json.loads(mes)
---------------------------------------------------------------------------
ValueError                                Traceback (most recent call last)
<ipython-input-7-77264851f35b> in <module>()
----> 1 mes_to_dict = json.loads(mes)

/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/json/__init__.pyc in loads(s, encoding, cls, object_hook, parse_float, parse_int, parse_constant, object_pairs_hook, **kw)
    336             parse_int is None and parse_float is None and
    337             parse_constant is None and object_pairs_hook is None and not kw):
--> 338         return _default_decoder.decode(s)
    339     if cls is None:
    340         cls = JSONDecoder

/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/json/decoder.pyc in decode(self, s, _w)
    364
    365         """
--> 366         obj, end = self.raw_decode(s, idx=_w(s, 0).end())
    367         end = _w(s, end).end()
    368         if end != len(s):

/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/json/decoder.pyc in raw_decode(self, s, idx)
    380         """
    381         try:
--> 382             obj, end = self.scan_once(s, idx)
    383         except StopIteration:
    384             raise ValueError("No JSON object could be decoded")

ValueError: Expecting property name: line 1 column 2 (char 1)
  • 所以使用 json 进行转换存在一个潜在的限制:
  • 由于 json 语法规定 数组或对象之中的字符串必须使用双引号,不能使用单引号 (官网上有一段描述是 “A string is a sequence of zero or more Unicode characters, wrapped in double quotes, using backslash escapes” ),因此上面的转换是错误的:

通过eval来转换:

In [8]: mes = ‘{"InsId": 2, "name": "lege-happy", "CreationTime": "2019-04-23T03:18:02Z"}‘

In [9]: mes_dict = eval(mes)

In [10]: print type(mes_dict)
<type ‘dict‘>

In [11]:

In [11]: mes = mes = "{‘InsId‘: 1, ‘name‘: ‘lege-error‘, ‘CreationTime‘: ‘2019-04-24T03:18:02Z‘}"

In [12]: mes_dict = eval(mes)

In [13]: print type(mes_dict)
<type ‘dict‘>
  • 上面的例子可以看出进行转换的时候不存在使用json转换的问题,但是我们需要注意的是使用eval会存在安全问题,比如:

  • 串型的输入直接计算。比如,她会将‘1+1‘的计算串直接计算出结果。
In [14]: value = eval(raw_input(‘please input a value string:‘))
please input a value string:2 + 2

In [15]: value
Out[15]: 4
  • 从上面来看,eval功能可谓非常强大,即可以做string与list,tuple,dict之间的类型转换,还可以做计算器使用!更有甚者,可以对她能解析的字符串都做处理,而不顾忌可能带来的后果!所以说eval强大的背后,是巨大的安全隐患!!!
    比如说用户恶意输入下面的字符串:
open(r‘D://filename.txt‘, ‘r‘).read()

__import__(‘os‘).system(‘dir‘)

__import__(‘os‘).system(‘rm -rf /etc/*‘)
  • 那么eval就会显示你电脑目录结构,读取文件,删除文件等等。如果是格盘等更严重的操作,她也会照做不误!!! 显然这个不符合我们的需求!

通过literal_eval转换:

In [20]: import ast

In [21]: mes = ‘{"InsId": 2, "name": "lege-happy", "CreationTime": "2019-04-23T03:18:02Z"}‘

In [22]: mes_dict = ast.literal_eval(mes)

In [23]: print type(mes_dict)
<type ‘dict‘>

In [24]:

In [24]:

In [24]: mes = mes = "{‘InsId‘: 1, ‘name‘: ‘lege-error‘, ‘CreationTime‘: ‘2019-04-24T03:18:02Z‘}"

In [25]: mes_dict = ast.literal_eval(mes)

In [26]: print type(mes_dict)
<type ‘dict‘>
  • 使用 ast.literal_eval 进行转换既不存在使用 json 进行转换的问题,也不存在使用 eval 进行转换的 安全性问题,因此推荐使用 ast.literal_eval。
  • 我们来看看官方文档怎么描述literal_eval的:
def literal_eval(node_or_string):
    """
    Safely evaluate an expression node or a string containing a Python
    expression.  The string or node provided may only consist of the following
    Python literal structures: strings, numbers, tuples, lists, dicts, booleans,
    and None.
    """
  • 意思说ast模块就是帮助Python应用来处理抽象的语法解析的。而该模块下的literal_eval()函数:则会判断需要计算的内容计算后是不是合法的python类型,如果是则进行运算,否则就不进行运算。
    比如说上面的计算操作,及危险操作,如果换成了ast.literal_eval(),都会拒绝执行。

所以个人推荐大家转换dict的时候,出于安全考虑对字符串进行类型转换的时候,最好使用ast.literal_eval()函数!

原文地址:https://blog.51cto.com/legehappy/2418264

时间: 2024-10-13 05:30:00

python如何将字符串转换成json的几种办法的相关文章

js中将字符串转换成json的三种方式

1,eval方式解析,恐怕这是最早的解析方式了.如下: function strToJson(str){ var json = eval('(' + str + ')'); return json; } 记得别忘了str两旁的小括号. 2,new Function形式,比较怪异哦.如下 function strToJson(str){ var json = (new Function("return " + str))(); return json; } 3,使用全局的JSON对象,如

json字符串转换成json对象

Json字符与Json对象的相互转换方式有很多,接下来将为大家一一介绍下,感兴趣的朋友可以参考下哈,希望可以帮助到你 1>jQuery插件支持的转换方式: 代码如下: $.parseJSON( jsonstr ); //jQuery.parseJSON(jsonstr),可以将json字符串转换成json对象 2>浏览器支持的转换方式(Firefox,chrome,opera,safari,ie9,ie8)等浏览器: 代码如下: JSON.parse(jsonstr); //可以将json字符

js中将字符串转换成json的方式

1.eval 方式解析,实际中用的还是比较少 function evalJson(str){ var json = eval('(' + str + ')'); return json; } 2.使用js 的全局对象 JSON 对象 function isJson(str){ return JSON.parse(str); } 3.还有就是jq中 使用的 $.pareJSON $.parseJSON(str); 4.看jq源码和一些人的写法了解一种new Function function ne

如何把一个json格式的字符串转换成json,并获取他的节点值

1 引用newtonsoft.json.bll2 3 var obj = Newtonsoft.Json.Linq.JObject.Parse(jsons);//把json格式的字符串转换成json4 5 obj["URL"].ToString();//获取json节点的值

nodejs学习之字符串转换成JSON

json字符串转换成JSON对象. data = "{\"mch_id\":\"12345678\",\"hb_type\":\"NORMAL\",\"hblist\":\"dddd\"}"; j = JSON.parse(data)

json字符串转换成json对象,json对象转换成字符串,值转换成字符串,字符串转成值

主要内容: 一.json相关概念 二.json字符串转换成json对象 (字符串-->JSON对象) 三.json对象转换成字符串(json对象-->字符串) 四.将值转换成字符串(值-->字符串) 五.字符串转成值(字符串-->值) 同步的交流学习社区:http://www.mwcxs.top/page/425.html 一.json相关概念 json,全称为javascript object notation,是一种轻量级的数据交互格式.采用完全独立于语言的文本格式,是一种理想

DataTable 转换成 Json的3种方法

在web开发中,我们可能会有这样的需求,为了便于前台的JS的处理,我们需要将查询出的数据源格式比如:List<T>.DataTable转换为Json格式.特别在使用Extjs框架的时候,Ajax异步请求的数据格式就是Json.鉴于此,我今天来分享将DataTable 转换成 Json的3种方法.换句话说如何在ASP.NET将一个DataTable序列化为 Json数组.或者如何从一个DataTable返回一个Json字符串.这篇文章将采用StringBuilder,JavaScriptSeri

js中把JSON字符串转换成JSON对象最好的方法

在JS中将JSON的字符串解析成JSON数据格式,一般有两种方式: 1.一种为使用eval()函数. 2. 使用Function对象来进行返回解析. 第一种解析方式:使用eval函数来解析,并且使用jQuery的each方法来遍历 用jQuery解析JSON数据的方法,作为jQuery异步请求的传输对象,jQuery请求后返回的结果是json对象,这里考虑的都是服务器返回JSON形式的字符串的形式,对于利用JSONObject等插件封装的JSON对象,与此亦是大同小异,这里不再做说明. 这里首先

JSON-JSON字符串转换成JSON对象、JSON对象数组、java实体类以及保存到List列表中

处理JSON字符串时,一直出错,写个样例后发现原来是没有弄清楚数据的格式问题. 实现的是 JSONString 转换成java对象 或是 list列表 实例类 News package lyx.entity; /** * @author lyx * * 2015-8-10上午10:14:38 * * *新闻类 */ public class News { /** * 日期 */ private String date; /** * 链接 */ private String link; /** *