转载地址: http://blog.csdn.net/bo_wen_/article/details/50868339
步骤1: 安装2个包
requests和beautifulsoup
步骤2:导入代码,并执行
import requests import csv import random import time import socket import http.client # import urllib.request from bs4 import BeautifulSoup def get_content(url , data = None): header={ 'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8', 'Accept-Encoding': 'gzip, deflate, sdch', 'Accept-Language': 'zh-CN,zh;q=0.8', 'Connection': 'keep-alive', 'User-Agent': 'Mozilla/5.0 (Windows NT 6.3; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/43.0.235' } timeout = random.choice(range(80, 180)) while True: try: rep = requests.get(url,headers = header,timeout = timeout) rep.encoding = 'utf-8' # req = urllib.request.Request(url, data, header) # response = urllib.request.urlopen(req, timeout=timeout) # html1 = response.read().decode('UTF-8', errors='ignore') # response.close() break # except urllib.request.HTTPError as e: # print( '1:', e) # time.sleep(random.choice(range(5, 10))) # # except urllib.request.URLError as e: # print( '2:', e) # time.sleep(random.choice(range(5, 10))) except socket.timeout as e: print( '3:', e) time.sleep(random.choice(range(8,15))) except socket.error as e: print( '4:', e) time.sleep(random.choice(range(20, 60))) except http.client.BadStatusLine as e: print( '5:', e) time.sleep(random.choice(range(30, 80))) except http.client.IncompleteRead as e: print( '6:', e) time.sleep(random.choice(range(5, 15))) return rep.text # return html_text def get_data(html_text): final = [] bs = BeautifulSoup(html_text, "html.parser") # 创建BeautifulSoup对象 body = bs.body # 获取body部分 data = body.find('div', {'id': '7d'}) # 找到id为7d的div ul = data.find('ul') # 获取ul部分 li = ul.find_all('li') # 获取所有的li for day in li: # 对每个li标签中的内容进行遍历 temp = [] date = day.find('h1').string # 找到日期 temp.append(date) # 添加到temp中 inf = day.find_all('p') # 找到li中的所有p标签 temp.append(inf[0].string,) # 第一个p标签中的内容(天气状况)加到temp中 if inf[1].find('span') is None: temperature_highest = None # 天气预报可能没有当天的最高气温(到了傍晚,就是这样),需要加个判断语句,来输出最低气温 else: temperature_highest = inf[1].find('span').string # 找到最高温 temperature_highest = temperature_highest.replace('℃', '') # 到了晚上网站会变,最高温度后面也有个℃ temperature_lowest = inf[1].find('i').string # 找到最低温 temperature_lowest = temperature_lowest.replace('℃', '') # 最低温度后面有个℃,去掉这个符号 temp.append(temperature_highest) # 将最高温添加到temp中 temp.append(temperature_lowest) #将最低温添加到temp中 final.append(temp) #将temp加到final中 return final def write_data(data, name): file_name = name with open(file_name, 'a', errors='ignore', newline='') as f: f_csv = csv.writer(f) f_csv.writerows(data) if __name__ == '__main__': url = 'http://www.weather.com.cn/weather/101190401.shtml' html = get_content(url) result = get_data(html) write_data(result, 'weather.csv')
步骤3: 结果如下:
23日(今天) | 多云 | 19 | 12 |
24日(明天) | 多云 | 20 | 12 |
25日(后天) | 多云 | 21 | 14 |
26日(周四) | 多云 | 21 | 14 |
27日(周五) | 多云 | 22 | 14 |
28日(周六) | 多云 | 21 | 15 |
29日(周日) | 多云转晴 | 21 | 11 |
相关推荐
1. **Python基础知识**:Python是一种高级编程语言,因其简洁明了的语法而常用于初学者入门。在这个项目中,Python被用来编写爬虫脚本,处理数据,以及实现数据可视化。你需要了解Python的基本语法,如变量、数据...
首先,系统将依赖于Python的网络爬虫功能来采集网络上的舆情数据。通过使用如requests、BeautifulSoup等库,可以方便地从新闻网站、社交媒体平台等处获取实时数据。数据采集后,接下来的步骤是对采集到的数据进行...
5G关键技术及进展.pdf
毕业论文-方熊表单V1.0.0 开源版-整站商业源码.zip
内容概要:本文档提供了红米Note12 5G版(代号sunstone)V14.0.10安卓13系统的fast线刷包下载.;其他说明:请确保在刷机前备份重要数据,仔细阅读刷机教程并严格按照步骤操作,避免因操作不当导致设备损坏。建议在官方指导下进行刷机操作。 资源说明; 1-----刷写前提是手机必须解锁bl先。而且会在fast模式刷写固件 2-----刷写方法与官方刷写步骤一样 3-----此固件为定制初始固件。可以在fast模式刷写 4-----属于适配固件。也许有个别bug。不接受请勿下载 5-----需要一定的刷机常识与动手能力的友友刷写。 6-----资源有可复制性。下载后不支持退。请知悉 7-----定制其他需求可以在csdn私信博主 参考博文了解详细: https://csdn9.blog.csdn.net/article/details/147775365?spm=1001.2101.3001.5352
毕业论文-活动报名小程序-整站商业源码.zip
3D金属打印的新进展.pdf
毕业论文-超级视频 2.0.10-整站商业源码.zip
毕业论文-超人配送代驾跑腿维修家政系统V1.5.10全开源解密版-整站商业源码.zip
实训商业源码-修罗-毕业设计.zip
ANSYS船舶与海洋工程解决方案介绍.pdf
毕业论文-彩虹易支付-整站商业源码.zip
ANSYS nCode高级疲劳技术培训.pdf
毕业论文-会议报名签到抽奖系统V1.0.6 开源版-整站商业源码.zip
毕业论文-萝卜视频-整站商业源码.zip
基于python+深度学习开发的中国交通警察指挥手势识别源码+数据集(毕业设计),该项目是个人毕设项目,答辩评审分达到98分,代码都经过调试测试,确保可以运行!欢迎下载使用,可用于小白学习、进阶。该资源主要针对计算机、通信、人工智能、自动化等相关专业的学生、老师或从业者下载使用,亦可作为期末课程设计、课程大作业、毕业设计等。项目整体具有较高的学习借鉴价值!基础能力强的可以在此基础上修改调整,以实现不同的功能。 基于python+深度学习开发的中国交通警察指挥手势识别源码+数据集(毕业设计)基于python+深度学习开发的中国交通警察指挥手势识别源码+数据集(毕业设计)基于python+深度学习开发的中国交通警察指挥手势识别源码+数据集(毕业设计)基于python+深度学习开发的中国交通警察指挥手势识别源码+数据集(毕业设计)基于python+深度学习开发的中国交通警察指挥手势识别源码+数据集(毕业设计)基于python+深度学习开发的中国交通警察指挥手势识别源码+数据集(毕业设计)基于python+深度学习开发的中国交通警察指挥手势识别源码+数据集(毕业设计)基于python+深度学习开发的中国交通警察指挥手势识别源码+数据集(毕业设计)基于python+深度学习开发的中国交通警察指挥手势识别源码+数据集(毕业设计)基于python+深度学习开发的中国交通警察指挥手势识别源码+数据集(毕业设计)基于python+深度学习开发的中国交通警察指挥手势识别源码+数据集(毕业设计)基于python+深度学习开发的中国交通警察指挥手势识别源码+数据集(毕业设计)基于python+深度学习开发的中国交通警察指挥手势识别源码+数据集(毕业设计)基于python+深度学习开发的中国交通警察指挥手势识别源码+数据集(毕业设计)基于python+深度学习开发的中国交通警察指挥手势识别源码+数据
实训商业源码-医疗小程序 5.9.6-毕业设计.zip
【研华科技】打造双碳智慧大脑,云领能源未来.pdf
毕业论文-伯乐发卡系统高级版源码-整站商业源码.zip