Python爬取天气网历史天气数据

我的第一篇博客,哈哈哈,记录一下我的Python进阶之路!

今天写了一个简单的爬虫。

使用Python的requests 和BeautifulSoup模块,Python 2.7.12可在命令行中直接使用pip进行模块安装。爬虫的核心是利用BeautifulSoup的select语句获取需要的信息。

pip install requests
pip install bs4

以武汉市2017年5~7月的历史为例爬取天气网中武汉市的历史天气数据。
7月对应的网址为http://lishi.tianqi.com/wuhan/201707.html

1.requests模块获取网页内容

url='http://lishi.tianqi.com/wuhan/201707.html'
response = requests.get(url)                          
soup = BeautifulSoup(response.text, 'html.parser')    

2.利用.select语句找到网页中天气数据所在的div

weather_list = soup.select('div[class="tqtongji2"]') 

天气数据所在的class

3.找出日期、最高气温、最低气温、天气等数据,用li.string获取li中的信息。

ul_list = weather.select('ul')
for ul in ul_list:
    li_list= ul.select('li')
    for li in li_list:
        li.string.encode('utf-8')  #具体的天气信息

详细天气信息获取

具体代码实现如下:

#encoding:utf-8                                                                      
import requests                                                                      
from bs4 import BeautifulSoup                                                        

urls = ["http://lishi.tianqi.com/wuhan/201707.html",                                 
        "http://lishi.tianqi.com/wuhan/201706.html",                                 
        "http://lishi.tianqi.com/wuhan/201705.html"]                                 
file = open('wuhan_weather.csv','w')                                                 
for url in urls:                                                                     
    response = requests.get(url)                                                     
    soup = BeautifulSoup(response.text, 'html.parser')                               
    weather_list = soup.select('div[class="tqtongji2"]')                             

    for weather in weather_list:                                                     
        weather_date = weather.select('a')[0].string.encode('utf-8')                 
        ul_list = weather.select('ul')                                               
        i=0                                                                          
        for ul in ul_list:                                                           
            li_list= ul.select('li')                                                 
            str=""                                                                   
            for li in li_list:                                                       
                str += li.string.encode('utf-8')+','                                 
            if i!=0:                                                                 
                file.write(str+'\n')                                                 
            i+=1                                                                     
file.close()                                                                         

最后的结果:
武汉5~7月天气

相比正则表达式,使用select语句爬取数据就是这么简单啦!
正则表达式还不是很理解,等理清楚,再来写总结。

  • 21
    点赞
  • 77
    收藏
    觉得还不错? 一键收藏
  • 13
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 13
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值