1. 程式人生 > >python筆記22-literal_eval函數處理返回json中的單雙引號

python筆記22-literal_eval函數處理返回json中的單雙引號

col 輸入 line 技術分享 listt 刪除 input expect lis

在做接口測試的時候,最常見的接口返回數據就是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() 函數用來執行一個字符串表達式,並返回表達式的值。

a = "hello"
b = "world"
# 把字符串裏面內容,當成運算
c = eval("a+b")
print(c)  # 返回結果 helloworld

d = eval("2+3+7*2")
print(d)  # 返回結果 19

e = 20
print(eval("e+2"))  # 返回結果 22

str轉list、tuple、dict

# str轉list

a = ‘[1, "a", None, True, [1, 2]]‘
print(eval(a))
print(type(eval(a)))

# str轉tuplue
b = ‘(1, "a", None, True, [1, 2])‘
print(eval(b))
print(type(eval(b)))

# str轉dict
c = ‘{"a": 1, "b": True, "c": None, "d": [1, 2], "e": {"a": 1}}‘
print(eval(c))
print(type(eval(c)))

運行結果:

[1, ‘a‘, None, True, [1, 2]]
<class ‘list‘>
(1, ‘a‘, None, True, [1, 2])
<class ‘tuple‘>
{‘a‘: 1, ‘b‘: True, ‘c‘: None, ‘d‘: [1, 2], ‘e‘: {‘a‘: 1}}
<class ‘dict‘>

單雙引號交替的json串

1.常見的json串,類似於這種{"isSucess":true, "name":"yoyo", "status": "200"},裏面的key和value都是雙引號。這種是可以用json模塊裏面的loads轉成字典的

import json
a = ‘{"isSucess":true, "name":"yoyo", "status": "200"}‘

b = json.loads(a)
print(b)
print(type(b))

運行結果

{‘isSucess‘: True, ‘name‘: ‘yoyo‘, ‘status‘: ‘200‘}
<class ‘dict‘>

2.有時候返回的json數據並不是標準的雙引號,裏面key和value有單引號也有雙引號,這種就比較坑了

{"isSucess":true, "result": ‘[{"name":"yoyo", "status": "200"}]‘}

import json

c = ‘‘‘{"isSucess":true, "result": ‘[{"name":"yoyo", "status": "200"}]‘}‘‘‘
d = json.loads(c)
print(d)

直接這樣用json去轉,會報錯:json.decoder.JSONDecodeError: Expecting value: line 1 column 29 (char 28)

3.解決辦法

  • 先替換json串裏面的true, false, null這種類型

f = ‘‘‘{"isSucess":true, "result": ‘[{"name":"yoyo", "status": "200"}]‘}‘‘‘
f1 = f.replace("true", "True").replace("false", "False").replace("null", "None")
print(eval(f1))

運行結果:
{‘isSucess‘: ‘True‘, ‘result‘: ‘[{"name":"yoyo", "status": "200"}]‘}

eval安全隱患

1.eval的功能通俗一點講就是把一個字符串理解成代碼去執行,如果用戶輸入一段惡意代碼,那就有安全隱患了,
比如導入os模塊後執行cmd指令,這樣就能對你的電腦為所欲為了,把你的重要文件刪除就尷尬了

導入os可以用__import__(‘os‘)去導入

# coding:utf-8

# __import__(‘os‘).system(‘whoami‘)
a = input("輸入:")
eval(a)

# __import__(‘os‘).system(‘dir‘)
b = input("請輸入:")
eval(b)

技術分享圖片

2.解決安全隱患,使用literal_eval方法。需先導入ast

import ast
f = ‘‘‘{"isSucess":true, "result": ‘[{"name":"yoyo", "status": "200"}]‘}‘‘‘
f1 = f.replace("true", "True").replace("false", "False").replace("null", "None")
print(ast.literal_eval(f1))
print(eval(f1))

python筆記22-literal_eval函數處理返回json中的單雙引號