python笔记22-literal_eval函数处理返回json中的单双引号

前言

在做接口测试的时候,最常见的接口返回数据就是json类型,json类型数据实际上就是字串,通常标准的json格式是可以转化成python里面的对应的数据类型的

有时候开发返回的数据比较坑,不按常理出牌,如下这种,result对应的是一个list数据,却又加了单引号变成了一个字符串

严格意义来讲,json串里面应该都是双引号,这种单双交替的就尴尬了

{“isSucess”:true, “result”: ‘[{“name”:”yoyo”, “status”: “200”}]’}

eavl

1.eval函数实现的功能

将字符串string对象转化为有效的表达式参

求值运算返回计算结果

2.语法:eval(expression,globals=None, locals=None)返回的是计算结果

expression是一个参与计算的python表达式

globals是可选的参数,如果设置属性不为None的话,就必须是dictionary对象了

locals也是一个可选的对象,如果设置属性不为None的话,可以是任何map对象了

求值运算

1.eval() 函数用来执行一个字符串表达式,并返回表达式的值。

str转list、tuple、dict

运行结果:

单双引号交替的json串

1.常见的json串,类似于这种{“isSucess”:true, “name”:”yoyo”, “status”: “200”},里面的key和value都是双引号。这种是可以用json模块里面的loads转成字典的

运行结果

2.有时候返回的json数据并不是标准的双引号,里面key和value有单引号也有双引号,这种就比较坑了

{“isSucess”:true, “result”: ‘[{“name”:”yoyo”, “status”: “200”}]’}

直接这样用json去转,会报错:json.decoder.JSONDecodeError: Expecting value: line 1 column 29 (char 28)

3.解决办法

先替换json串里面的true, false, null这种类型

运行结果:

{‘isSucess’: ‘True’, ‘result’: ‘[{“name”:”yoyo”, “status”: “200”}]’}

eval安全隐患

1.eval的功能通俗一点讲就是把一个字符串理解成代码去执行,如果用户输入一段恶意代码,那就有安全隐患了,

比如导入os模块后执行cmd指令,这样就能对你的电脑为所欲为了,把你的重要文件删除就尴尬了

导入os可以用import(‘os’)去导入

2.解决安全隐患,使用literal_eval方法。需先导入ast

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20180718G0YIJS00?refer=cp_1026
  • 腾讯「云+社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 yunjia_community@tencent.com 删除。

扫码关注云+社区

领取腾讯云代金券