python 使用eval报错NameError: name ‘null’ is not defined

python 使用eval报错NameError: name ‘null’ is not defined

eval()函数十分强大,它可以把list,tuple,dict和string相互转化。

最近的项目中用到了eval,使用eval将string转化成list。其中有一组数据在转化时报错:NameError: name ‘null’ is not defined

经过排查,发现string数据中包含‘null’,在转换时就会报上面的错误

data = "[{"id":1,"value":null},{"id":2,"value":"国外"}]" 
result= eval(data)
print(result)

解决方法:

使用replace,将字符串中的null替换掉!

data = "[{"id":1,"value":null},{"id":2,"value":"国外"}]" data = data.replace(null,  )result= eval(data)print(result)

这样就能正常转换了

下面介绍一下在数据转换中,json与eval的区别:

1、json.loads与eval都能将s转成python中的对象,json.loads将json中的字符串转成unicode(types.UnicodeType),eval转成了str(types.StringType)。

2、json不认单引号,json中的字符串需要用双引号包起来

推荐阅读

    excel怎么用乘法函数

    excel怎么用乘法函数,乘法,函数,哪个,excel乘法函数怎么用?1、首先用鼠标选中要计算的单元格。2、然后选中单元格后点击左上方工具栏的fx公

    无法读取U盘中的数据

    无法读取U盘中的数据,,核心提示:我有一个512MB的U盘,把它插在电脑显示器里面是空的,但右键单击以查看已经使用USB 480mb文件的属性未设置为隐

    excel中乘法函数是什么?

    excel中乘法函数是什么?,乘法,函数,什么,打开表格,在C1单元格中输入“=A1*B1”乘法公式。以此类推到多个单元。1、A1*B1=C1的Excel乘法公式

    标准差excel用什么函数?

    标准差excel用什么函数?,函数,标准,什么,在数据单元格的下方输入l标准差公式函数公式“=STDEVPA(C2:C6)”。按下回车,求出标准公差值。详细

    字符库快捷键|字符串快捷键

    字符库快捷键|字符串快捷键,,1. 字符串快捷键1、单行注释单行注释是 #Mac的快捷键是 command+/windows的快捷键是 Ctrl + /2、多行注

    EXCEL数据透视表怎么用?是干什么的

    EXCEL数据透视表怎么用?是干什么的,透视,干什么,怎么,excel透视表:数据透视表(Pivot Table)是一种交互式的表,可以进行某些计算,如求和与计数等