| 
 | 
 
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册  
 
x
 
在小甲鱼的ooxx那一课,为什么我的程序会报这个错误 
- import urllib.request
 
 - import os
 
  
- def url_open(url):
 
 -     req=urllib.request.Request(url)
 
 -     req.add_header('User-Agent','Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/45.0.2454.101 Safari/537.36')
 
 -     response=urllib.request.urlopen(url)
 
 -     html=response.read()
 
 -     return html
 
  
- def get_page(url):
 
 -     html=url_open(url).decode('utf-8')
 
 -     a=html.find('current-comment-page')+23
 
 -     b=html.find(']',a)
 
 -     return html[a:b]
 
 -     
 
 - def find_imgs(url):
 
 -     html=url_open(url).decode('utf-8')
 
 -     img_addrs=[]
 
 -     a=html.find('img src=')
 
 -     while a!=-1:
 
 -         b=html.find('.jpg',a,a+255)
 
 -         if b!=-1:
 
 -             img_addrs.append(html[a+9:b+4])
 
 -         else:
 
 -             b=a+9
 
 -         a=html.find('img src=',b)
 
 -     return img_addrs
 
  
- def save_imgs(folder,img_addrs):
 
 -     for each in img_addrs:
 
 -         filename=each.split('/')[-1]
 
 -         with open(filename,'wb') as f:
 
 -             img=url_open(each)
 
 -             f.write(img)
 
 -     
 
 - def download_mm(folder='OOXX',pages=10):
 
 -     os.mkdir(folder)
 
 -     os.chdir(folder)
 
 -     url=r'http://jandan.net/ooxx/'
 
 -     page_num=int(get_page(url))
 
 -     for i in range(pages):
 
 -         page_num-=i
 
 -         page_url=url+'page-'+str(page_num)+'#comments'
 
 -         img_addrs=find_imgs(page_url)
 
 -         save_imgs(folder,img_addrs)
 
  
- if __name__=='__main__':
 
 -     download_mm()
 
  复制代码 Traceback (most recent call last): 
  File "E:/小甲鱼—《零基础入门学习Python》/056轮一只爬虫的自我修养4:OOXX/1.爬图片.py", line 49, in <module> 
    download_mm() 
  File "E:/小甲鱼—《零基础入门学习Python》/056轮一只爬虫的自我修养4:OOXX/1.爬图片.py", line 46, in download_mm 
    save_imgs(folder,img_addrs) 
  File "E:/小甲鱼—《零基础入门学习Python》/056轮一只爬虫的自我修养4:OOXX/1.爬图片.py", line 34, in save_imgs 
    img=url_open(each) 
  File "E:/小甲鱼—《零基础入门学习Python》/056轮一只爬虫的自我修养4:OOXX/1.爬图片.py", line 5, in url_open 
    req=urllib.request.Request(url) 
  File "E:\python\lib\urllib\request.py", line 329, in __init__ 
    self.full_url = url 
  File "E:\python\lib\urllib\request.py", line 355, in full_url 
    self._parse() 
  File "E:\python\lib\urllib\request.py", line 384, in _parse 
    raise ValueError("unknown url type: %r" % self.full_url) 
ValueError: unknown url type: '//wx1.sinaimg.cn/mw600/66b3de17gy1ffxkfmik4lj20dw0jpwgz.jpg'
一个笨方法,每次爬取的地址你都看看是否是tp://s.jandan.com/static/gg/lanya2.jpg 
如果是那么就不加入图片地址(就是你的24行) 
每次执行加入图片地址(24行代码)之前用 
if html[a+9:b+4] != 'tp://s.jandan.com/static/gg/lanya2.jpg': 
    img_addrs.append(html[a+11:b+4])
  
 
 
 |   
 
 
 
 |