菜菜子nn 2022-01-12 23:15 采纳率: 83.3%
浏览 42
已结题

请问beautifulsoup里面怎么拼接网址呀?

就是因为这个爬取的网站他有一个主url,然后里面的子页面源代码都是后面不一样,想着怎么让他们拼接起来,我自己的代码如下,求指点

import requests
from bs4 import BeautifulSoup
import time
url = "https://www.umei.cc/p/gaoqing/"
resp = requests.get(url)
resp.encoding = "utf-8"
# print(resp.text)
# 把源代码交给BS4
main_page = BeautifulSoup(resp.text, "html.parser")
alist = main_page.find("div", class_="TypeList").find_all("a")

# print(alist)
for a in alist:
    href = a.get('href')  # 直接通过get拿到属性的值
    #拿到子页面的源代码
    child_page_resp = requests.get(href)
    child_page_resp.encoding = 'utf-8'
    child_page_text = child_page_resp.text
    # 从子页面中拿到图片的下载链接
    child_page = BeautifulSoup(child_page_text, "html.parser")
    p = child_page.find("div", id_="ArticleId")
    img = p.find("img")
    print(img.get("src"))
    #下载图片
    img_resp = requests.get(src)
    # img_resp.content  # 这里拿到的是字节,字节写到文件里不就是图片嘛
    img_name = src.split("/")[-1]  #拿到url中最后一个/以后的内容
    with open("img/"+img_name, mode="wb") as f:
        f.write(img_resp.content) #图片内容写入文件
    print("over!", img_name)
    time.sleep(1)
print("all over")

  • 写回答

2条回答 默认 最新

  • 猫猫爱吃鱼 2022-01-13 11:16
    关注
    import requests
    from bs4 import BeautifulSoup
    import time
    url = "https://www.umei.cc/p/gaoqing/"
    resp = requests.get(url)
    resp.encoding = "utf-8"
    # print(resp.text)
    # 把源代码交给BS4
    main_page = BeautifulSoup(resp.text, "html.parser")
    alist = main_page.find("div", class_="TypeList").find_all("a")
    # print(alist)
    for a in alist:
        href = ‘{0}/{1}'.format(url, a.get('href'))
        #拿到子页面的源代码
        child_page_resp = requests.get(href)
        child_page_resp.encoding = 'utf-8'
        child_page_text = child_page_resp.text
        # 从子页面中拿到图片的下载链接
        child_page = BeautifulSoup(child_page_text, "html.parser")
        p = child_page.find("div", id_="ArticleId")
        img = p.find("img")
        src = '{0}/{1}'.format(url, img.get("src"))
        #下载图片
        img_resp = requests.get(src)
        # img_resp.content  # 这里拿到的是字节,字节写到文件里不就是图片嘛
        img_name = src.split("/")[-1]  #拿到url中最后一个/以后的内容
        with open("img/"+img_name, mode="wb") as f:
            f.write(img_resp.content) #图片内容写入文件
        print("over!", img_name)
        time.sleep(1)
    print("all over")
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 1月21日
  • 已采纳回答 1月13日
  • 创建了问题 1月12日

悬赏问题

  • ¥15 WPF动态创建页面内容
  • ¥15 如何对TBSS的结果进行统计学的分析已完成置换检验,如何在最终的TBSS输出结果提取除具体值及如何做进一步相关性分析
  • ¥15 SQL数据库操作问题
  • ¥100 关于lm339比较电路出现的问题
  • ¥15 Matlab安装yalmip和cplex功能安装失败
  • ¥15 加装宝马安卓中控改变开机画面
  • ¥15 STK安装问题问问大家,这种情况应该怎么办
  • ¥15 关于罗技鼠标宏lua文件的问题
  • ¥15 halcon ocr mlp 识别问题
  • ¥15 已知曲线满足正余弦函数,根据其峰值,还原出整条曲线