已解决TypeError: eval() arg 1 must be a string, bytes or code object

news/2024/7/18 15:05:47 标签: python, 爬虫, 开发语言, eval

已解决TypeError: eval() arg 1 must be a string, bytes or code object






文章目录

  • 报错问题
  • 报错翻译
  • 报错原因
  • 解决方法
  • 联系博主免费帮忙解决报错





报错问题



粉丝群里面的一个小伙伴,想用Python爬虫然后解析数据,但是发生了报错(当时他心里瞬间凉了一大截,跑来找我求助,然后顺利帮助他解决了,顺便记录一下希望可以帮助到更多遇到这个bug不会解决的小伙伴),报错代码如下所示:

def spider(page=1):
    """

    :param page:
    :return:
    """
    url = "http://www.ceic.ac.cn/ajax/search?page={}&&start=2021-01-01&&end=2021-12-31&&jingdu1=&&jingdu2=&&weidu1=&&weidu2=&&height1=&&height2=&&zhenji1=&&zhenji2=&&callback=jQuery180008241254755365413_1671790451896&_=1671790540769".format(
        page)
    params = {}
    headers = {
        "User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/108.0.0.0 Safari/537.36"
    }
    resp = requests.get(url=url, params=params, headers=headers)
    print(type(resp))
    data = resp.content.decode("utf-8")
    data = re.sub("jQuery180008241254755365413_1671790451896\(",'',data)
    data = re.sub("\)$", '', data)

    data = eval(data)
    # data = resp.content.decode("utf-8").strip("(").strip(")")
    print(data,type(data))
    #
    data1 = data['shuju'][0]
    print(data1)
    print(type(data1))
    data1 = eval(data1)
    data_dic = json.loads(data1) # .get("shuju")
    data_arr = []
    for data in data_dic:
        data_info = {
            "M": data.get("M"),
            "O_TIME": data.get("O_TIME"),
            "EPI_LAT": data.get("EPI_LAT"),
            "EPI_LON": data.get("EPI_LON"),
            "EPI_DEPTH": data.get("EPI_DEPTH"),
            "LOCATION_C": data.get("LOCATION_C")
        }
        data_arr.append(data_info)
    print(data_arr)

报错信息截图所示


在这里插入图片描述




报错翻译



报错信息翻译如下所示

类型错误 :eval()参数1必须是字符串、字节或代码对象





报错原因



报错原因

粉丝在一次使用Python eval()函数时,出现报错了,当时也不知道什么原因,后面经过我给他讲解解决了这个问题,也重新认识了eval()函数。

小伙伴按下面的方式解决即可!!!




解决方法



eval函数的参数必须为字符串,否则将报错:

  • 1、 检查是否为字符串,可以检查类型
  • 2、是否有为空的行(粉丝就是这个原因)

以上是此问题报错原因的解决方法,欢迎评论区留言讨论是否能解决,博主看到会给出回复和你所遇到的报错问题解决方法!!!

联系博主免费帮忙解决报错

本文已收录于:《告别Bug专栏》,欢迎免费订阅!!!

本专栏用于记录学习和工作中遇到的各种疑难编程Bug问题,以及粉丝群里小伙伴提出的各种问题,文章形式:报错代码 + 报错翻译 + 报错原因 + 解决方法,包括程序安装、运行程序过程中遇到的等等问题,博主心愿:让天下没有难学的编程,从此告别Bug!!!

订阅专栏 + 关注博主后,扫描下方二维码进全栈学习互助交流群可以帮忙解决问题,并且可以免费领取300本IT电子书籍、学习资料、简历模板、面试题库,和小伙伴们交流学习、抱团取暖,共同进步!!!

资料获取 | 技术交流 | 抱团学习 | 咨询分享 请点击下方名片后扫描二维码

在这里插入图片描述


http://www.niftyadmin.cn/n/32237.html

相关文章

用最简单的方法实现个人网站-wordpress结合LAMP架构实战

文章目录前言一、LAMP架构是什么?1.1 LAMP架构简介1.2 什么是apache?1.3 什么是MySQL?1.4 什么是php?二. wordpress是什么三. 搭建博客过程1. 实验环境2. 搭建LAMP架构3. 设置数据库并授权4. 上传wordpress并解压5. 修改配置文件6. 网页端进…

park unpark 原理

1、基本使用 // 暂停当前线程 LockSupport.park();// 恢复某个线程的运行 LockSupport.unpark(暂停线程对象) 先 park 再 unpark public class Test1 {public static void main(String[] args) throws InterruptedException {Thread t1 new Thread(() -> {log.debug(&q…

用 NFTScan 的角度解析 Yuga labs NFT 项目系列

如果要说 NFT 影响力最大的公司是哪个?如果说是 Yuga Labs 应该我想大家应该都不会否认。一个创立一年多的 NFT 营销和开发公司,多次的并购以及行销操作都立下 NFT 界的标竿典范,尤其 BAYC NFT 系列取得巨大成功之后,该团队已成为…

编写一个简版的数据库维护框架03-父窗口界面

框架的主要内容就是创建一个父类Form,实现基本逻辑。使用时,这些逻辑就无需用户实现。用户只需按照规则,设计好界面即可。 一、简版界面 界面如下: 界面分为两大部分,查询定位和数据维护 查询定位 查询定位将根据…

RabbitMQ-客户端源码之ChannelN

ChannelN是整个RabbitMQ客户端最核心的一个类了,其包含的功能点甚多,这里需要分类阐述。 首先来看看ChannelN的成员变量: private final Map _consumers Collections.synchronizedMap(new HashMap()); private volatile Consumer defaultCo…

常用RTOS详细说明

鸿蒙OS HarmonyOS是一款面向全场景的开源分布式操作系统,是华为自主研发的操作系统。 鸿蒙OS实现模块化耦合,可应用在不同的设备上。 鸿蒙OS架构分为三层: 第一层是内核第二层是基础服务第三层是程序框架 。 鸿蒙OS底层三部分组成&#x…

若依框架文档开发手册----开发中常用功能模块

目录 前端 add.html 时间框 大文本框 Ajax校验 自定义校验 回显选中图片 JS对添加下拉列元素 edit.html 下拉列 回显时间 list.html 搜索栏 时间框 mapper.xml Table表格 格式化时间 前端 表格匹配字典值 表格增加.减少功能项 全局 其他 关闭标签页 输入框…

SpringBoot整合第三方技术

SpringBoot整合第三方技术 文章目录SpringBoot整合第三方技术整合JunitSpringBoot整合MyBatis整合Junit 在Boot环境下如何进行单元测设 注解:SpringBootTest 类型:测试类注解 位置:测试类上方 作用:设置JUnit加载的SpringBoot启…