weixin_51366727 2022-03-30 23:22 采纳率: 50%
浏览 742
已结题

python报错:lxml.etree.XPathEvalError: Invalid expression,如何解决?

我在一个B站视频里跟着敲爬小说的python代码,和他的一摸一样,但是我的一直在报错,网上也没有正确的解决方法,就问一下大家。
操作环境、软件版本等信息
问题相关代码
import requests
from lxml import etree

class Spider(object):
    def start_request(self):
    #1.请求拿到小说名创建文件夹
        response = requests.get("https://www.qidian.com/all")
        html = etree.HTML(response.text)
        Bigtit_list = html.xpath('//<div[@class="book-mid-info"]/h2/a/text()')
        Bigsrc_list = html.xpath('//<div[@class="book-mid-info"]/h2/a/@href')
        print(Bigtit_list, Bigsrc_list)


spider = Spider()
spider.start_request()

运行结果及报错内容
C:\Users\acer\PycharmProjects\pythonProject\venv\Scripts\python.exe C:/Users/acer/PycharmProjects/pythonProject/有声小说网站/小说抓取.py
Traceback (most recent call last):
  File "C:/Users/acer/PycharmProjects/pythonProject/有声小说网站/小说抓取.py", line 15, in <module>
    spider.start_request()
  File "C:/Users/acer/PycharmProjects/pythonProject/有声小说网站/小说抓取.py", line 9, in start_request
    Bigtit_list = html.xpath('//<div[@class="book-mid-info"]/h2/a/text()')
  File "src\lxml\etree.pyx", line 1597, in lxml.etree._Element.xpath
  File "src\lxml\xpath.pxi", line 305, in lxml.etree.XPathElementEvaluator.__call__
  File "src\lxml\xpath.pxi", line 225, in lxml.etree._XPathEvaluatorBase._handle_result
lxml.etree.XPathEvalError: Invalid expression

Process finished with exit code 1


我的解答思路和尝试过的方法

我觉得问题主要是看lxml.etree.XPathEvalError: Invalid expression
但是我根本没有找到什么解决方法,欢迎帮忙解答一下

我想要达到的结果
  • 写回答

2条回答 默认 最新

      报告相同问题?

      相关推荐 更多相似问题

      问题事件

      • 系统已结题 4月7日
      • 已采纳回答 3月30日
      • 创建了问题 3月30日

      悬赏问题

      • ¥15 如何关闭soui dummy wdn 进程
      • ¥20 含有jar文件的文件夹用tar -zcvf 命令压缩后要怎么还原回去?
      • ¥15 天宝TBC软件出现报错怎么解决
      • ¥15 micropython 从1开始切片报错
      • ¥15 请问该怎么做才能将文字说明和二维码一起作为png图片一起下载
      • ¥15 r语言 混频数据回归 midas_r
      • ¥15 人脸识recogizer.predict返回值id报错,KeyError,详情如下
      • ¥15 geowebcache部署失败
      • ¥20 关于adaboost+haar特征实现人脸检测过程的一些细节问题
      • ¥15 csv文件增加一列 为csv文件的名字