weixin_46415501 2020-03-22 13:23 采纳率: 66.7%
浏览 438
已采纳

scrapy框架问题报错?

import scrapy
import bs4
from ..items import DoubanItem

需要引用DoubanItem,它在items里面。因为是items在top250.py的上一级目录,所以要用..items,这是一个固定用法。

class DoubanSpider(scrapy.Spider): #定义一个爬虫类DoubanSpider
name = 'douban'
allower_domains = ['book.douban.com'] #定义允许爬虫爬取的网址域名
start_urls = []
for x in range(3):
url = 'https://book.douban.com/top250?start=' + str(x * 25) #定义起始网址
start_urls.append(url)

def parse(self,response):
#parse是默认处理response的方法。
    bs = bs4.BeautifulSoup(response.text,'html.parse')
    #用BeautifulSoup解析response。
    datas = bs.find_all('tr',class_="item")
    #用find_all提取<tr class="item">元素,这个元素里含有书籍信息。
    for data in datas:
    #遍历data。
        item = doubanItem()
        #实例化DoubanItem这个类。
        item['title'] = data.find_all('a')[1]['title']
        #提取出书名,并把这个数据放回DoubanItem类的title属性里。
        item['publish'] = data.find('p',class_='pl').text
        #提取出出版信息,并把这个数据放回DoubanItem类的publish里。
        item['score'] = data.find('span',class_='rating_nums').text
        #提取出评分,并把这个数据放回DoubanItem类的score属性里。
        print(item['title'])
        #打印书名。
        yield item
        #yield item是把获得的item传递给引擎。



    Traceback (most recent call last):

File "D:\hello-world.py\pythoncode\douban\douban\spiders\top250.py", line 3, in
from ..items import DoubanItem
ValueError: attempted relative import beyond top-level package

网上的办法试了几种都w'x,不知道是我搞错了还是什么问题,求解!!!

  • 写回答

1条回答 默认 最新

  • threenewbee 2020-03-22 19:02
    关注
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 TMC2209串口模式下读取不到寄存器的值串口助手蓝色字体是发过去的消息,绿色字体是收到的消息,第二行发送读取寄存器的指令但是没有读取到寄存器的值串口助手如下图:接线如下图,如何解决?
  • ¥15 高通安卓11提取完整线刷包软件,或者优博讯dt50顺丰刷机包
  • ¥20 C,有个译码器,换了信道就跑不出原来数据
  • ¥15 MIMIC数据库安装问题
  • ¥60 基于JTag协议开发Fpga下载器上位机,哪位大🐂有偿指导?
  • ¥20 全书网Java爬取数据
  • ¥15 怎么获取红包封面的原始链接,并且获取红包封面序列号
  • ¥100 微信小程序跑脚本授权的问题
  • ¥100 房产抖音小程序苹果搜不到安卓可以付费悬赏
  • ¥15 STM32串口接收问题