爬取100多个城市的历史天气

本文介绍了如何使用Python爬取包括三亚、三门峡、上海、上饶、东莞、东营等在内的多个城市的天气历史数据。首先,从数据源中获取并处理城市名称,注意到2345天气中的城市名不包含“市”。然后,匹配城市ID以便进一步获取数据,并对降雨量进行特殊标记,最后执行实际的天气数据爬取操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

import pandas as pd
import numpy as np
import re
import os
import json
#import js2py
import requests
from bs4 import BeautifulSoup
from urllib.parse import urlencode
import time   #用于时间的停顿
import random 

接着取出想要爬取的城市名

file = pd.read_csv(r'C:\Users\信息明细表.csv').loc[:,['service_date','city','service_result']]
city_name = list(file.groupby('city').city.count().index)
city_name

output:
[‘三亚市’,
‘三门峡市’,
‘上海市’,
‘上饶市’,
‘东莞市’,
‘东营市’,
…]
由于发现2345天气的城市 不带“市”,所以去掉

city=[]
for i in city_name:
    r = re.sub('市', '', i) 
    city.append(r)

找出城市对应的ID

def get_areaid(city):
    url = 'http://tianqi.2345.com/tqpcimg/tianqiimg/theme4/js/citySelectData2.js'
    r = requests.get(url)
    print(r.encoding, r.apparent_encoding)
    r.encoding = r.apparent
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值