python将字符串转换成json的方法小结


Posted in Python onJuly 09, 2019

最近在工作中遇到了一个小问题,如果要将字符串型的数据转换成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()函数!

总结

以上所述是小编给大家介绍的python将字符串转换成json的方法小结 ,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Python 相关文章推荐
使用Python脚本操作MongoDB的教程
Apr 16 Python
Python类定义和类继承详解
May 08 Python
在Python中操作字典之update()方法的使用
May 22 Python
web.py 十分钟创建简易博客实现代码
Apr 22 Python
Python引用传值概念与用法实例小结
Oct 07 Python
Python+matplotlib实现华丽的文本框演示代码
Jan 22 Python
python爬取酷狗音乐排行榜
Feb 20 Python
TensorFlow实现简单的CNN的方法
Jul 18 Python
Python 使用 PyMysql、DBUtils 创建连接池提升性能
Aug 14 Python
python中web框架的自定义创建
Sep 08 Python
PYTHON绘制雷达图代码实例
Oct 15 Python
Django 设置admin后台表和App(应用)为中文名的操作方法
May 10 Python
Python绘制堆叠柱状图的实例
Jul 09 #Python
python3 线性回归验证方法
Jul 09 #Python
python time.sleep()是睡眠线程还是进程
Jul 09 #Python
python logging模块的使用总结
Jul 09 #Python
Django中如何使用sass的方法步骤
Jul 09 #Python
python执行scp命令拷贝文件及文件夹到远程主机的目录方法
Jul 08 #Python
使用python socket分发大文件的实现方法
Jul 08 #Python
You might like
php array_walk_recursive 使用自定的函数处理数组中的每一个元素
2016/11/16 PHP
模拟多级复选框效果的jquery代码
2013/08/13 Javascript
使用JQuery库提供的扩展功能实现自定义方法
2014/09/09 Javascript
Angularjs手动解析表达式($parse)
2016/10/12 Javascript
简单实现JavaScript弹幕效果
2020/08/27 Javascript
vue使用stompjs实现mqtt消息推送通知
2017/06/22 Javascript
js 客户端打印html 并且去掉页眉、页脚的实例
2017/11/03 Javascript
vue bus全局事件中心简单Demo详解
2018/02/26 Javascript
解决vue-cli创建项目的loader问题
2018/03/13 Javascript
Vue Prop属性功能与用法实例详解
2019/02/23 Javascript
Angular脚手架开发的实现步骤
2019/04/09 Javascript
javascript/jquery实现点击触发事件的方法分析
2019/11/11 jQuery
JS代码优化的8点建议
2020/02/04 Javascript
Node.js API详解之 module模块用法实例分析
2020/05/13 Javascript
vue实现在线学生录入系统
2020/05/30 Javascript
JS实现鼠标按下拖拽效果
2020/07/23 Javascript
[02:44]DOTA2英雄基础教程 钢背兽
2013/12/19 DOTA
CentOS中使用virtualenv搭建python3环境
2015/06/08 Python
浅析Python 3 字符串中的 STR 和 Bytes 有什么区别
2018/10/14 Python
numpy基础教程之np.linalg
2019/02/12 Python
python连接、操作mongodb数据库的方法实例详解
2019/09/11 Python
Python解释器以及PyCharm的安装教程图文详解
2020/02/26 Python
python实现将字符串中的数字提取出来然后求和
2020/04/02 Python
keras 权重保存和权重载入方式
2020/05/21 Python
python Yaml、Json、Dict之间的转化
2020/10/19 Python
Python从文件中读取数据的方法步骤
2020/11/18 Python
Pytorch1.5.1版本安装的方法步骤
2020/12/31 Python
CSS3 3D位移translate效果实例介绍
2016/05/03 HTML / CSS
Cole Haan官方网站:美国时尚潮流品牌
2017/12/06 全球购物
欧洲最大的预定车位市场:JustPark
2020/01/06 全球购物
Zalando Lounge瑞士:时尚与生活方式购物俱乐部
2020/03/12 全球购物
工地食品安全责任书
2015/05/09 职场文书
2015年全民创业工作总结
2015/07/23 职场文书
OpenCV-Python 实现两张图片自动拼接成全景图
2021/06/11 Python
Java使用jmeter进行压力测试
2021/07/09 Java/Android
nginx从安装到配置详细说明(安装,安全配置,防盗链,动静分离,配置 HTTPS,性能优化)
2022/02/12 Servers