版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、2.6.1 项目简介2.6.1 项目简介在中国天气网()中输入一个城市的名称,例如输入深圳,那么会转到地址/weather1d/101280601.shtml的网页显示深圳的天气预报,其中101280601是深圳的代码,每个城市或者地区都有一个代码。如图2-6-1、2-6-2所示。2.6.2 HTML代码分析2.6.2 HTML代码分析用Chrome浏览器浏览网站,鼠标指向7天天气预报的今天位置,点击右键弹出菜单,选择“检查”就可以打开这个位置对应的HTML代码,如图2-6-3所示。选择元素,点击右键弹出菜单选择Edit as HTML,就可以进入编辑状态,复制整个HTML,结果如下:5日(今
2、天)多云32/28微风6日(明天)多云32/27微风7日(后天)多云32/27微风8日(周四)多云32/27微风9日(周五)多云33/27微风10日(周六)多云33/27微风11日(周日)多云转小雨33/26微风2.6.3 爬取天气预报数据2.6.3 爬取天气预报数据通过分析HTML代码,我们可以编写爬取的程序爬取深圳7天的天气预报数据:from bs4 import BeautifulSoupfrom bs4 import UnicodeDammitimport urllib.requesturl=/weather/101280601.shtmltry: headers=User-Agent
3、:Mozilla/5.0 (Windows; U; Windows NT 6.0 x64; en-US; rv:1.9pre) Gecko/2008072421 Minefield/3.0.2pre req=urllib.request.Request(url,headers=headers) data=urllib.request.urlopen(req) data=data.read() dammit=UnicodeDammit(data,utf-8,gbk) data=dammit.unicode_markup soup=BeautifulSoup(data,lxml) lis=soup
4、.select(ulclass=t clearfix li) for li in lis: try: date=li.select(h1)0.text weather=li.select(pclass=wea)0.text temp=li.select(pclass=tem span)0.text+/+li.select(pclass=tem i)0.text print(date,weather,temp) except Exception as err: print(err)except Exception as err: print(err)程序爬取结果:5日(今天) 多云 32/286
5、日(明天) 多云 32/277日(后天) 多云 32/278日(周四) 多云 32/279日(周五) 多云 33/2710日(周六) 多云 33/2711日(周日) 多云转小雨 33/26由此可见爬取的数据与我们直接从网站看到的是一样的。2.6.4 爬取与存储天气预报数据2.6.4 爬取与存储天气预报数据我们可以获取北京、上海、广州、深圳等城市的代码,爬取这些城市的天气预报数据,并存储到sqllite数据库weathers.db中,存储的数据表weathers是:create table weathers (wCity varchar(16),wDate varchar(16),wWeathe
6、r varchar(64),wTemp varchar(32),constraint pk_weather primary key (wCity,wDate)编写程序依次爬取各个城市的天气预报数据存储在数据库中,程序如下:from bs4 import BeautifulSoupfrom bs4 import UnicodeDammitimport urllib.requestimport sqlite3class WeatherDB: def openDB(self): self.con=sqlite3.connect(weathers.db) self.cursor=self.con.cu
7、rsor() try: self.cursor.execute(create table weathers (wCity varchar(16),wDate varchar(16),wWeather varchar(64),wTemp varchar(32),constraint pk_weather primary key (wCity,wDate) except: self.cursor.execute(delete from weathers) def closeDB(self): mit() self.con.close()def insert(self,city,date,weath
8、er,temp): try: self.cursor.execute(insert into weathers (wCity,wDate,wWeather,wTemp) values (?,?,?,?) ,(city,date,weather,temp) except Exception as err: print(err) def show(self): self.cursor.execute(select * from weathers) rows=self.cursor.fetchall() print(%-16s%-16s%-32s%-16s % (city,date,weather,
9、temp) for row in rows: print(%-16s%-16s%-32s%-16s % (row0,row1,row2,row3)class WeatherForecast: def _init_(self): self.headers = User-Agent: Mozilla/5.0 (Windows; U; Windows NT 6.0 x64; en-US; rv:1.9pre) Gecko/2008072421 Minefield/3.0.2pre self.cityCode=北京:101010100,上海:101020100,广州:101280101,深圳:1012
10、80601def forecastCity(self,city): if city not in self.cityCode.keys(): print(city+ code cannot be found) return url=/weather/+self.cityCodecity+.shtml try: req=urllib.request.Request(url,headers=self.headers) data=urllib.request.urlopen(req) data=data.read() dammit=UnicodeDammit(data,utf-8,gbk) data
11、=dammit.unicode_markup soup=BeautifulSoup(data,lxml) lis=soup.select(ulclass=t clearfix li)for li in lis: try: date=li.select(h1)0.text weather=li.select(pclass=wea)0.text temp=li.select(pclass=tem span)0.text+/+li.select(pclass=tem i)0.text print(city,date,weather,temp) self.db.insert(city,date,wea
12、ther,temp) except Exception as err: print(err) except Exception as err: print(err)def process(self,cities): self.db=WeatherDB() self.db.openDB() for city in cities: self.forecastCity(city) #self.db.show() self.db.closeDB()ws=WeatherForecast()cess(北京,上海,广州,深圳)print(completed)北京 7日(今天) 晴间多云,北部山区有阵雨或雷阵
13、雨转晴转多云 31/17北京 8日(明天) 多云转晴,北部地区有分散阵雨或雷阵雨转晴 34/20北京 9日(后天) 晴转多云 36/22北京 10日(周六) 阴转阵雨 30/19北京 11日(周日) 阵雨 27/18北京 12日(周一) 阴转晴 28/20北京 13日(周二) 晴 32/21上海 7日(今天) 多云 30/21上海 8日(明天) 多云转阴 32/23上海 9日(后天) 阵雨 32/24上海 10日(周六) 中雨 27/22上海 11日(周日) 小雨转多云 29/22上海 12日(周一) 多云 30/22上海 13日(周二) 多云转阴 30/21广州 7日(今天) 多云 35/27广州 8日(明天) 多云 35/28广州 9日(后天) 多云 35/28广州 10日(周六)
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 《个案工作的原理》课件
- 《游轮礼仪》课件
- 2024商业空间广告装饰施工协议版A版
- 2024年度供货合作模板协议文件版B版
- 2024年大班语言活动教案绘本《漏》
- 2024年工商行政管理局工作计划
- 2024小学二年级班主任工作计划第一学期例文
- 2024年大班科学教案800字
- 2024年土木结构工程人力分包标准协议书版B版
- 2024年专业降水工程标准协议范本版B版
- 电气仪表工程签证需要注意的问题案例
- 书信的写作-(PPT课件17张)
- 三年级作文——观察桔子-PPT课件(共24张)
- 工地试验室仪器设备自校规程
- 防爆电气设备安全管理制度
- KJ551煤矿微地震监测系统简介和技术参数
- 形式发票格式2 INVOICE
- 商业模式画布
- 高速公路箱梁装梁与运输方案
- 肖申克 的救赎PPT
- 护理操作——皮下注射操作评分标准 操作流程
评论
0/150
提交评论