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里使用正则表达式的全匹配功能
Oct 19 Python
python批量读取txt文件为DataFrame的方法
Apr 03 Python
详解python中的json和字典dict
Jun 22 Python
python调用matlab的m自定义函数方法
Feb 18 Python
利用python求积分的实例
Jul 03 Python
django基础学习之send_mail功能
Aug 07 Python
python创建与遍历List二维列表的方法
Aug 16 Python
Python笔记之观察者模式
Nov 20 Python
解决TensorFlow GPU版出现OOM错误的问题
Feb 03 Python
pandas读取csv文件提示不存在的解决方法及原因分析
Apr 21 Python
Keras 加载已经训练好的模型进行预测操作
Jun 17 Python
使用Python中tkinter库简单gui界面制作及打包成exe的操作方法(二)
Oct 12 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
Protoss兵种对照表
2020/03/14 星际争霸
多数据表共用一个页的新闻发布
2006/10/09 PHP
PHP+javascript液晶时钟
2006/10/09 PHP
用PHP即时捕捉PHP中的错误并发送email通知的实现代码
2013/01/19 PHP
MongoDB在PHP中的常用操作小结
2014/02/20 PHP
php遍历删除整个目录及文件的方法
2015/03/13 PHP
ExtJS PropertyGrid中使用Combobox选择值问题
2010/06/13 Javascript
JS实现多物体缓冲运动实例代码
2013/11/29 Javascript
jQuery - css() 方法示例详解
2014/01/16 Javascript
js实现纯前端的图片预览
2016/04/27 Javascript
javaScript基础详解
2017/01/19 Javascript
AngularJs上传前预览图片的实例代码
2017/01/20 Javascript
jq stop()和:is(:animated)的用法及区别(详解)
2017/02/12 Javascript
Bootstrap媒体对象学习使用
2017/03/07 Javascript
nodeJS微信分享
2017/12/20 NodeJs
React Form组件的实现封装杂谈
2018/05/07 Javascript
Webpack中雪碧图插件使用详解
2018/05/25 Javascript
layui 优化button按钮和弹出框的方法
2018/08/15 Javascript
Javascript实现动态时钟效果
2018/11/17 Javascript
nodejs各种姿势断点调试的方法
2020/06/18 NodeJs
Python处理字符串之isspace()方法的使用
2015/05/19 Python
Python遍历目录中的所有文件的方法
2016/07/08 Python
Python3.遍历某文件夹提取特定文件名的实例
2018/04/26 Python
Python实现的查询mysql数据库并通过邮件发送信息功能
2018/05/17 Python
解决python 无法加载downsample模型的问题
2018/10/25 Python
python3 pygame实现接小球游戏
2019/05/14 Python
Django组件cookie与session的具体使用
2019/06/05 Python
Python3标准库之functools管理函数的工具详解
2020/02/27 Python
Python Tkinter Entry和Text的添加与使用详解
2020/03/04 Python
keras训练浅层卷积网络并保存和加载模型实例
2020/07/02 Python
Jupyter Notebook 远程访问配置详解
2021/01/11 Python
使用before和:after伪类制作css3圆形按钮
2014/04/08 HTML / CSS
Perfume’s Club澳大利亚官网:西班牙领先的在线美容店
2021/02/01 全球购物
学历公证书范本
2014/04/09 职场文书
数学教育专业求职信
2014/07/22 职场文书
销售内勤岗位职责
2015/02/10 职场文书