正解python3 json报错:from None json.decoder.JSONDecodeError: Expecting value: line 1 column 6 (char 5)

本文详细解析了在Ubuntu16.04LTS环境下,使用Python3.x进行字符串到JSON对象转换时遇到的错误“Expecting value: line 1 column 6 (char 5)”。介绍了错误产生的原因,通常是因为JSON字符串中的NULL关键字不被识别,以及如何通过try...except语句捕获异常和使用正确的数据类型来避免此类问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

环境

  • Ubuntu 16.04 LTS
  • python3.x

问题描述

  • 从字符串转换为json对象时,报错如下:

    Traceback (most recent call last):
      File "<stdin>", line 1, in <module>
      File "/usr/lib/python3.5/json/__init__.py", line 319, in loads
        return _default_decoder.decode(s)
      File "/usr/lib/python3.5/json/decoder.py", line 339, in decode
        obj, end = self.raw_decode(s, idx=_w(s, 0).end())
      File "/usr/lib/python3.5/json/decoder.py", line 357, in raw_decode
        raise JSONDecodeError("Expecting value", s, err.value) from None
    json.decoder.JSONDecodeError: Expecting value: line 1 column 6 (char 5)
    
    
  • 示例代码:

    import json
    
    str_json = '{"a":NULL, "b":1}'
    json_data = json.loads(str_json)
    
    

错误原因分析

str_json中从第5个字符开始是非法字符,也就是’NULL’
【】总之,这类错误就说明是json字符串是非法的:比如格式错误、值类型错误等


解决方案

  • 1、使用try抛出异常,跳过错误数据

    import json
    	
    str_json = '{"a":NULL, "b":1}'
    try:
        json_data = json.loads(str_json)
    except Exception as e:
        print('error:', e)
    

    输出:

    error: Expecting value: line 1 column 6 (char 5)
    
  • 2、从源头解决

    数据转为json字符串时,使用json.dumps()函数,加载字符串为对象时用json.loads

    import json
    
    json_data = {"a":None, "b":1}
    print('json_data:', json_data)
    
    str_json = json.dumps(json_data) #使用json.dumps()函数
    print('str_json:', str_json)
    
    json_data = json.loads(str_json)
    print('json_data:', json_data)
    

    输出:

    json_data: {'a': None, 'b': 1}
    str_json: {"a": null, "b": 1}
    json_data: {'a': None, 'b': 1}
    

    可以看到 str_json 中出现 null ,而不是 None/NULL。

### Python 测试登录时遇到的 JSON 解码错误解决方案 当处理 `json.decoder.JSONDecodeError` 错误时,通常是因为尝试解析的内容不是有效的 JSON 字符串。此异常可能发生在多种场景下,特别是在 API 请求返回的数据不符合预期的情况下[^1]。 对于测试登录功能而言,如果服务器响应为空或者格式不正确,则会触发此类错误。为了防止这种情况发生,在执行任何涉及 JSON 的操作之前,应该先验证接收到的数据确实是一个合法的 JSON 文本。可以通过捕获潜在的解码失败来实现这一点: ```python import json from requests import post def login(username, password): url = "https://example.com/api/login" payload = {"username": username, "password": password} try: response = post(url, data=payload) result = response.json() # 尝试将响应体转换成字典对象 if isinstance(result, dict): return result.get(&#39;token&#39;) or None except ValueError as e: # 捕捉所有由于非法输入引起的ValueError print(f"Failed to decode JSON from server: {e}") return None except Exception as ex: print(f"An unexpected error occurred during the request: {ex}") raise ``` 此外,考虑到某些情况下数据源可能会提供空字符串或其他非结构化形式的结果,建议在发送请求前检查这些特殊情况并作出适当调整。例如,确保 Excel 文件中的 JSON 数据项不会包含未定义或 NULL 值;必要时可以使用默认值填充缺失字段[^3]。 最后值得注意的是,如果是在开发环境中工作,务必确认所使用的库版本是最新的,并且遵循官方文档推荐的最佳实践来进行编码[^2]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

szZack

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值