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实现的金山快盘的签到程序
Jan 17 Python
Python自动化构建工具scons使用入门笔记
Mar 10 Python
Python将xml和xsl转换为html的方法
Mar 10 Python
Python简单进程锁代码实例
Apr 27 Python
全面解析Python的While循环语句的使用方法
Oct 13 Python
Python Requests 基础入门
Apr 07 Python
Python的Tornado框架实现异步非阻塞访问数据库的示例
Jun 30 Python
python3 selenium 切换窗口的几种方法小结
May 21 Python
对Python中9种生成新对象的方法总结
May 23 Python
python多进程提取处理大量文本的关键词方法
Jun 05 Python
用python3教你任意Html主内容提取功能
Nov 05 Python
Cpython解释器中的GIL全局解释器锁
Nov 09 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中邮箱地址正则表达式实现与详解
2012/04/24 PHP
PHP购物车类Cart.class.php定义与用法示例
2016/07/20 PHP
PHP中include/require/include_once/require_once使用心得
2016/08/28 PHP
ThinkPHP发送邮件示例代码
2016/10/08 PHP
Laravel学习教程之从入口到输出过程详解
2017/08/27 PHP
Confirmer JQuery确认对话框组件
2010/06/09 Javascript
jQuery EasyUI API 中文文档 - Tabs标签页/选项卡
2011/10/01 Javascript
jquery 插件学习(三)
2012/08/06 Javascript
解决JS浮点数运算出现Bug的方法
2013/03/12 Javascript
jQuery实现tab选项卡效果的方法
2015/07/08 Javascript
JavaScript位置与大小(1)之正确理解和运用与尺寸大小相关的DOM属性
2015/12/26 Javascript
Bootstrap如何激活导航状态
2017/03/22 Javascript
解决vue中虚拟dom,无法实时更新的问题
2018/09/15 Javascript
layui禁用侧边导航栏点击事件的解决方法
2019/09/25 Javascript
js实现轮播图效果 z-index实现轮播图
2020/01/17 Javascript
Vue过滤器,生命周期函数和vue-resource简单介绍
2021/01/12 Vue.js
python解析xml模块封装代码
2014/02/07 Python
跟老齐学Python之有容乃大的list(3)
2014/09/15 Python
Python函数嵌套实例
2014/09/23 Python
Python中的choice()方法使用详解
2015/05/15 Python
Python实现列表转换成字典数据结构的方法
2016/03/11 Python
举例讲解Python中字典的合并值相加与异或对比
2016/06/04 Python
python结合selenium获取XX省交通违章数据的实现思路及代码
2016/06/26 Python
Python + OpenCV 实现LBP特征提取的示例代码
2019/07/11 Python
Python中filter与lambda的结合使用详解
2019/12/24 Python
tensorflow使用range_input_producer多线程读取数据实例
2020/01/20 Python
Python selenium模拟手动操作实现无人值守刷积分功能
2020/05/13 Python
巴塞罗那观光通票:Barcelona Pass
2019/10/30 全球购物
开办加工厂创业计划书
2014/01/03 职场文书
大学生活自我评价
2014/04/09 职场文书
《山谷中的谜底》教学反思
2014/04/26 职场文书
订货会主持词
2015/07/01 职场文书
2015高中教师个人工作总结
2015/07/21 职场文书
办公室日常管理制度
2015/08/04 职场文书
2019下半年英语教师的教学工作计划(3篇)
2019/09/25 职场文书
详解Oracle数据库中自带的所有表结构(sql代码)
2021/11/20 Oracle