鱼C论坛

 找回密码
 立即注册
查看: 3298|回复: 11

[学习笔记] 我的第一个爬虫

[复制链接]
发表于 2019-12-30 21:25:30 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
废话少说,先上图:
1.png
    在网上下载gho系统时,找到了一个叫技术员联盟的网站(http://www.jsgho.net),有个图片的标签,点开一看,哇,全是美女(穿了衣服的),刚好学到爬虫,练练手吧。观察了一下,发现所有的图片都在www.jsgho.net/image/下面,查看了一上网页的源代码,图片在<li></li>标签的<img src里面,不过有个小问题就是网址不全,取下来后还要加上网站的地址,开工。(附全部网址),新人,代码写的很烂,请大神们多多指点,谢谢。
  1. import requests
  2. from bs4 import BeautifulSoup
  3. import re
  4. import os


  5. def getHTMLText(url):
  6.     try:
  7.         headers = {'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 '
  8.                                  '(KHTML, like Gecko) Chrome/78.0.3904.97 Safari/537.36'}
  9.         r = requests.get(url, headers=headers)
  10.         r.raise_for_status()
  11.         r.encoding = 'utf-8'
  12.         return r.text
  13.     except:
  14.         return ''

  15. def get_img(html):
  16.     try:
  17.         p = r'<li><img src="([^"]*\.jpg)"'
  18.         imglist = re.findall(p, html)
  19.         soup = BeautifulSoup(html, 'lxml')
  20.         name = soup.title.text
  21.         root = r"D:\Pictures//"
  22.         path = root + name
  23.     except:
  24.         print("")

  25.     try:
  26.         os.mkdir(path)
  27.     except FileExistsError:
  28.         pass

  29.     os.chdir(path)

  30.     for each in imglist:
  31.         filename = each.split('/')[-1]
  32.         url = "http://www.jsgho.net"
  33.         each = url + each
  34.         r = requests.get(each)

  35.         with open(filename, 'wb') as f:
  36.             f.write(r.content)

  37. def main(url):
  38.     html = getHTMLText(url)
  39.     get_img(html)


  40. with open("C://Users//Administrator//Desktop//sitemap.txt") as f:
  41.     urls = f.readlines()

  42. for url in urls:
  43.     url = url.strip('\n')
  44.     main(url)
复制代码

sitemap.rar

432 Bytes, 下载次数: 7

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2019-12-31 13:34:52 | 显示全部楼层
Traceback (most recent call last):
  File "D:\python\test.py", line 2, in <module>
    from bs4 import BeautifulSoup
ModuleNotFoundError: No module named 'bs4'

请问这个错误是哪错了
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-12-31 14:55:42 | 显示全部楼层
czfasaoyou 发表于 2019-12-31 13:34
Traceback (most recent call last):
  File "D:\python\test.py", line 2, in
    from bs4 import Bea ...

没有 bs4 模块
需要安装,在命令行下运行:  pip install bs4
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-12-31 16:27:51 | 显示全部楼层
谢谢
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2019-12-31 16:30:40 | 显示全部楼层
UnicodeDecodeError: 'gbk' codec can't decode byte 0x80 in position 11: illegal multibyte sequence,这个又是哪里错了?谢谢
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-12-31 20:58:15 | 显示全部楼层
czfasaoyou 发表于 2019-12-31 16:30
UnicodeDecodeError: 'gbk' codec can't decode byte 0x80 in position 11: illegal multibyte sequence, ...

编码错误,把完整的异常提示发来看看。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-1-2 16:49:52 | 显示全部楼层
Traceback (most recent call last):
  File "D:\python\test.py", line 52, in <module>
    urls = f.readlines()
UnicodeDecodeError: 'gbk' codec can't decode byte 0x80 in position 11: illegal multibyte sequence
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-1-2 21:03:24 | 显示全部楼层
czfasaoyou 发表于 2020-1-2 16:49
Traceback (most recent call last):
  File "D:\python\test.py", line 52, in
    urls = f.readlines ...

把这句with open("C://Users//Administrator//Desktop//sitemap.txt") as f:
改成with open("C://Users//Administarator//Desktop//sitemap.txt", encoding='utf-8') as f:看看

还有你要看看你下载的sitemap.txt文件的路径,把C://Users//Administarator//Desktop替换成你的sitemap.txt的路径。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-1-4 14:05:11 | 显示全部楼层
谢谢,我试试
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-1-4 14:16:20 | 显示全部楼层
修改,运行的时候提出错误syntaxerror  invalid character in identifier ,光标停在encoding
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-1-4 16:22:58 | 显示全部楼层
czfasaoyou 发表于 2020-1-4 14:16
修改,运行的时候提出错误syntaxerror  invalid character in identifier ,光标停在encoding

直接复制的吗?看看有没有中文的空格。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-1-6 16:01:46 | 显示全部楼层
直接复制的
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-5-11 10:48

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表