需要对某网站的图片进行爬取,编写一个硬生程序,要求保留图片名称,用代码在系统的D盘新建—个文件夹,名称为 PIC,用要求代码健壮,捕捉错误,返回通信代码和异常

时间: 2023-04-12 07:00:21 浏览: 72
非常感谢您的提问。以下是我为您提供的代码: ```python import requests import os url = "https://example.com/images/" # 替换为需要爬取的网站图片链接 folder_name = "PIC" save_path = f"D:\\{folder_name}" # 在系统D盘新建一个名为PIC的文件夹 try: os.makedirs(save_path, exist_ok=True) # 如果文件夹已存在,不会抛出异常 response = requests.get(url) response.raise_for_status() # 如果请求失败,会抛出异常 with open(os.path.join(save_path, os.path.basename(url)), "wb") as f: f.write(response.content) print("通信代码:200") except Exception as e: print(f"异常:{e}") print("通信代码:500") ``` 这段代码可以从指定的网站链接中爬取图片,并将其保存到系统D盘下的一个名为PIC的文件夹中。如果程序出现异常,会返回通信代码500,否则返回通信代码200。
相关问题

需要对网页图片进行爬取编写代码,要求保留图片名称,用代码在D盘新建一个文件夹,名称为pic捕获错误返回通信代码还有异常

可以使用Python的requests和BeautifulSoup库来实现对网页图片的爬取和保存。以下是示例代码: ```python import requests from bs4 import BeautifulSoup import os url = "https://www.example.com" # 替换为需要爬取的网页地址 response = requests.get(url) soup = BeautifulSoup(response.text, "html.parser") img_tags = soup.find_all("img") folder_path = "D:/pic" # 新建文件夹路径 if not os.path.exists(folder_path): os.makedirs(folder_path) for img in img_tags: img_url = img["src"] img_name = img_url.split("/")[-1] # 获取图片名称 img_path = os.path.join(folder_path, img_name) try: img_response = requests.get(img_url) with open(img_path, "wb") as f: f.write(img_response.content) except (requests.exceptions.RequestException, IOError): print("捕获错误返回通信代码还有异常") ``` 注意:在实际使用时,需要替换url和folder_path变量的值为实际需要爬取的网页地址和保存图片的文件夹路径。

如何用Python编写一个爬取网上图片并保存在电脑D盘的代码

### 回答1: 首先,需要安装相关的库,如requests和bs4。接着,可以编写以下代码实现爬取图片并保存在本地: ``` import requests from bs4 import BeautifulSoup # 爬取网页的图片地址 def get_image_urls(url): headers = { 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/86.0.4240.111 Safari/537.36' } response = requests.get(url, headers=headers) soup = BeautifulSoup(response.text, 'html.parser') image_tags = soup.find_all('img') urls = [img.get('src') for img in image_tags] return urls # 保存图片 def save_images(urls): for url in urls: response = requests.get(url) with open('D:/' + url.split("/")[-1], 'wb') as f: f.write(response.content) # 爬取图片 url = "https://www.example.com" # 输入需要爬取图片的网页地址 image_urls = get_image_urls(url) save_images(image_urls) ``` 这段代码中,`get_image_urls`函数用于爬取图片的地址,`save_images`函数用于将图片保存到本地。将需要爬取的网页地址替换为实际的地址,运行代码即可。 ### 回答2: 要用Python编写一个爬取网上图片并保存在电脑D盘的代码,首先需要导入以下模块:requests、os、random和time。然后,可以按照以下步骤编写代码: 1. 设定目标图片的URL地址,可以是单个或多个URL地址。 2. 使用requests模块的get()方法发送HTTP请求,获取图片的二进制数据。 3. 创建一个文件夹来保存图片,可以使用os模块的mkdir()方法。 4. 使用os模块的chdir()方法切换到D盘的路径。 5. 使用open()函数打开文件,使用'wb'模式(二进制写入模式)。 6. 使用文件对象的write()方法将图片的二进制数据写入到文件中。 7. 关闭文件。 8. 重复步骤2到步骤7,直到所有的图片都被爬取并保存。 下面是一个简单的示例代码: ``` import requests import os import random import time # 目标图片URL地址 urls = ['https://example.com/image1.jpg', 'https://example.com/image2.jpg', 'https://example.com/image3.jpg'] # 创建保存图片的文件夹 os.mkdir('D:/images') # 切换到D盘路径 os.chdir('D:/') for url in urls: # 发送HTTP请求,获取图片的二进制数据 response = requests.get(url) # 生成随机的文件名 filename = f'image_{random.randint(1, 10000)}.jpg' # 使用'wb'模式打开文件,写入二进制数据 with open(f'images/{filename}', 'wb') as file: file.write(response.content) # 随机休眠几秒,以免给服务器带来过大压力 time.sleep(random.randint(1, 5)) print('图片爬取完成并保存在D盘的images文件夹中。') ``` 请注意,这只是一个简单的示例代码,实际需要根据具体的需求进行修改和改进,如增加异常处理、多线程等。 ### 回答3: 要用Python编写一个爬取网上图片并保存在电脑D盘的代码,可以使用requests和os库来实现。 首先,需要导入requests和os库: ``` import requests import os ``` 接下来,定义一个函数用于下载图片: ```python def download_image(url, save_path): response = requests.get(url) if response.status_code == 200: with open(save_path, 'wb') as f: f.write(response.content) print("图片保存成功!") else: print("图片下载失败!") ``` 然后,定义一个函数用于获取网页的图片链接: ```python def get_image_urls(url): response = requests.get(url) if response.status_code == 200: image_urls = [img['src'] for img in response.content.find_all('img')] return image_urls else: print("获取图片链接失败!") return [] ``` 最后,编写主函数来实现整个爬取和保存图片的过程: ```python def main(): url = "http://example.com" # 替换成你要爬取图片的网页链接 save_dir = "D:\\images" # 替换成你想保存图片的目录 # 创建保存图片的目录 if not os.path.exists(save_dir): os.mkdir(save_dir) # 获取图片链接 image_urls = get_image_urls(url) # 依次下载并保存图片 for i, image_url in enumerate(image_urls): file_name = f"image_{i}.jpg" # 图片文件名 save_path = os.path.join(save_dir, file_name) download_image(image_url, save_path) if __name__ == "__main__": main() ``` 这样,通过运行主函数,就可以爬取指定链接的图片,并保存在电脑D盘的指定目录中。注意替换代码中的网页链接和保存目录为你自己的目标网址和路径。

相关推荐

最新推荐

recommend-type

Python使用xpath实现图片爬取

主要介绍了Python使用xpath实现图片爬取,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
recommend-type

Python requests30行代码爬取知乎一个问题的所有回答

Python requests30行代码爬取知乎一个问题的所有回答 之前学习了Python的requests爬虫一直想找机会自己练习下,正好作为一个大学生平时知乎看的也不少,那就爬取知乎吧,先上源码和效果图(我找的是随便一个热门问题...
recommend-type

利用Python爬取微博数据生成词云图片实例代码

主要给大家介绍了关于利用Python爬取微博数据生成词云图片的相关资料,文中通过示例代码介绍非常详细,对大家学习或者使用python具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。
recommend-type

grpcio-1.14.0-cp36-cp36m-macosx_10_7_intel.whl

Python库是一组预先编写的代码模块,旨在帮助开发者实现特定的编程任务,无需从零开始编写代码。这些库可以包括各种功能,如数学运算、文件操作、数据分析和网络编程等。Python社区提供了大量的第三方库,如NumPy、Pandas和Requests,极大地丰富了Python的应用领域,从数据科学到Web开发。Python库的丰富性是Python成为最受欢迎的编程语言之一的关键原因之一。这些库不仅为初学者提供了快速入门的途径,而且为经验丰富的开发者提供了强大的工具,以高效率、高质量地完成复杂任务。例如,Matplotlib和Seaborn库在数据可视化领域内非常受欢迎,它们提供了广泛的工具和技术,可以创建高度定制化的图表和图形,帮助数据科学家和分析师在数据探索和结果展示中更有效地传达信息。
recommend-type

哈尔滨工程大学825经济学2020考研专业课初试大纲.pdf

哈尔滨工程大学考研初试大纲
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

MATLAB结构体与对象编程:构建面向对象的应用程序,提升代码可维护性和可扩展性

![MATLAB结构体与对象编程:构建面向对象的应用程序,提升代码可维护性和可扩展性](https://picx.zhimg.com/80/v2-8132d9acfebe1c248865e24dc5445720_1440w.webp?source=1def8aca) # 1. MATLAB结构体基础** MATLAB结构体是一种数据结构,用于存储和组织相关数据。它由一系列域组成,每个域都有一个名称和一个值。结构体提供了对数据的灵活访问和管理,使其成为组织和处理复杂数据集的理想选择。 MATLAB中创建结构体非常简单,使用struct函数即可。例如: ```matlab myStruct
recommend-type

详细描述一下STM32F103C8T6怎么与DHT11连接

STM32F103C8T6可以通过单总线协议与DHT11连接。连接步骤如下: 1. 将DHT11的VCC引脚连接到STM32F103C8T6的5V电源引脚; 2. 将DHT11的GND引脚连接到STM32F103C8T6的GND引脚; 3. 将DHT11的DATA引脚连接到STM32F103C8T6的GPIO引脚,可以选择任一GPIO引脚,需要在程序中配置; 4. 在程序中初始化GPIO引脚,将其设为输出模式,并输出高电平,持续至少18ms,以激活DHT11; 5. 将GPIO引脚设为输入模式,等待DHT11响应,DHT11会先输出一个80us的低电平,然后输出一个80us的高电平,
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。