鱼C论坛

 找回密码
 立即注册
查看: 1013|回复: 13

[已解决]爬虫问题

[复制链接]
发表于 2020-4-1 16:54:13 | 显示全部楼层 |阅读模式

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

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

x
本帖最后由 齐紫荆。 于 2020-4-1 17:30 编辑

如图,为啥爬出来的tr是个空的啊
最佳答案
2020-4-1 17:59:34
本帖最后由 qiuyouzhi 于 2020-4-1 18:01 编辑
齐紫荆。 发表于 2020-4-1 17:44
>>> table = soup.find('table',class_="wikitable").children
>>> for tr in table:
        if isinstance(t ...


顺便给你包装了一下:
  1. from requests import get
  2. from bs4 import BeautifulSoup as BS

  3. def open_url(url):
  4.     # 可以加headers
  5.     res = get(url)
  6.     return res

  7. def get_Info(res):
  8.     soup = BS(res.text, "html.parser")
  9.     table = soup.find('table').children
  10.     i = 0 # 它用于判断何时该换行
  11.     for tr in list(table)[1]:
  12.         if i == 2:
  13.             print()
  14.             i = 0
  15.         print(tr.string.strip(), end = '') # strip()删除空格
  16.         i += 1
  17.         

  18. def main():
  19.     url = "https://yanyu.huijiwiki.com/wiki/伙伴成长以及加点属性排行一览"
  20.     get_Info(open_url(url))

  21. if __name__ == "__main__":
  22.     main()
复制代码
f2484d202786ad2706fc6ffd094fc23.png
W9WI2Y~}9~9}HPOQK6SW~DL.png
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-4-1 16:56:09 | 显示全部楼层
确定几个东西:
1,URL没错?
2,不加headers能爬?
3,soup.find确定找到东西了?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-1 17:06:14 | 显示全部楼层
没有这个 页面啊   你是从哪里跳转过去的
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-4-1 17:28:33 | 显示全部楼层
qiuyouzhi 发表于 2020-4-1 16:56
确定几个东西:
1,URL没错?
2,不加headers能爬?

页面没错啊,我用r.status_code返回是200,应该是对的,table = soup.find('table')也有东西啊
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-1 17:31:40 | 显示全部楼层
齐紫荆。 发表于 2020-4-1 17:28
页面没错啊,我用r.status_code返回是200,应该是对的,table = soup.find('table')也有东西啊

那你确定<table>有子标签,且你的isinstance参数拼写正确?
那个bs4.element.Tag为何点后有空格?
去掉试试
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-1 17:33:18 | 显示全部楼层
齐紫荆。 发表于 2020-4-1 17:28
页面没错啊,我用r.status_code返回是200,应该是对的,table = soup.find('table')也有东西啊

顺便你把find后面加个参数:
  1. class_="wikitable"
复制代码

我怀疑你的find找到第一个table后,里面没有子标签
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-4-1 17:34:33 | 显示全部楼层
qiuyouzhi 发表于 2020-4-1 17:31
那你确定有子标签,且你的isinstance参数拼写正确?
那个bs4.element.Tag为何点后有空格?
去掉试试

大佬你看我补的那个图,那个tr应该是table的子标签吧
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-1 17:35:30 | 显示全部楼层
齐紫荆。 发表于 2020-4-1 17:34
大佬你看我补的那个图,那个tr应该是table的子标签吧

我又回复你了,看下6楼
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-4-1 17:44:30 | 显示全部楼层
qiuyouzhi 发表于 2020-4-1 17:35
我又回复你了,看下6楼

>>> table = soup.find('table',class_="wikitable").children
>>> for tr in table:
        if isinstance(tr,bs4.element.Tag):
                th = tr('th')

               
>>> th
[]
这样吗还是空的啊
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-1 17:54:15 | 显示全部楼层
齐紫荆。 发表于 2020-4-1 17:44
>>> table = soup.find('table',class_="wikitable").children
>>> for tr in table:
        if isinstance(t ...

给你调试了一下,正确方法是酱紫的:
  1. >>> for each in list(table)[1]:
  2.         print(each.string)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-1 17:59:34 | 显示全部楼层    本楼为最佳答案   
本帖最后由 qiuyouzhi 于 2020-4-1 18:01 编辑
齐紫荆。 发表于 2020-4-1 17:44
>>> table = soup.find('table',class_="wikitable").children
>>> for tr in table:
        if isinstance(t ...


顺便给你包装了一下:
  1. from requests import get
  2. from bs4 import BeautifulSoup as BS

  3. def open_url(url):
  4.     # 可以加headers
  5.     res = get(url)
  6.     return res

  7. def get_Info(res):
  8.     soup = BS(res.text, "html.parser")
  9.     table = soup.find('table').children
  10.     i = 0 # 它用于判断何时该换行
  11.     for tr in list(table)[1]:
  12.         if i == 2:
  13.             print()
  14.             i = 0
  15.         print(tr.string.strip(), end = '') # strip()删除空格
  16.         i += 1
  17.         

  18. def main():
  19.     url = "https://yanyu.huijiwiki.com/wiki/伙伴成长以及加点属性排行一览"
  20.     get_Info(open_url(url))

  21. if __name__ == "__main__":
  22.     main()
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-4-1 18:00:34 | 显示全部楼层
qiuyouzhi 发表于 2020-4-1 17:54
给你调试了一下,正确方法是酱紫的:

大佬这个只能输出第一排,怎么输出整个表啊
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-1 18:01:23 | 显示全部楼层
齐紫荆。 发表于 2020-4-1 18:00
大佬这个只能输出第一排,怎么输出整个表啊

我给你包装了一下,详情看11楼
我这里测试是没有问题的
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-4-1 18:05:01 | 显示全部楼层
qiuyouzhi 发表于 2020-4-1 17:59
顺便给你包装了一下:

感谢大佬
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-4-19 12:08

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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