這套課程雖然叫爬蟲入門類課程,可是裏面涉及到的點是很是多,十分檢驗你的基礎掌握的牢固程度,代碼中的不少地方都是能夠細細品味的。html
爲何要寫這麼一個小東東呢,由於我生活在大河北,那霧霾醇厚的很,去了趟三亞,那空氣,嘖嘖,舒服的很,因此爬取一下三亞天氣,看看何時去最好,理想的溫度爲24~28,呵呵噠python
代碼走起來 ,天氣類的網址多的很,重點關注歷史天氣 找到這麼一個網站 www.tianqi.com/sanya/app
發現入口,哈哈,有機會爬取到簡單的requests,複雜的scrapy 總有一款適合你的python爬蟲
哇哦~從2011年到2019年都有唉scrapy
月份點進去,呈現了大概這些信息,最高氣溫,最低氣溫,天氣,風向,風力,好了數據都有了 lishi.tianqi.com/sanya/20110… 到這個地方不着急,慢慢來,一個每天寫爬蟲的人必需要對URL敏感,一看就嗨,小時候喜歡找規律的人長大都能寫爬蟲URL 是這樣子的 lishi.tianqi.com/sanya/20111… lishi.tianqi.com/sanya/20110… lishi.tianqi.com/sanya/20110… lishi.tianqi.com/sanya/20110…ide
lishi.tianqi.com/[三亞的拼音]/年月.…網站
OK,這就簡單了,走起,看起來就簡單,那我就使用pyspider了 ,很久沒有,都有點遺忘了呢 怎麼運行呢? spa
沒有特別複雜的地方,基本就屬於常規操做了3d
def __init__(self):
self._city = "sanya"
def get_date_list(self,begin,end):
date_list = [x.strftime("%Y%m") for x in list(pd.date_range(start=begin,end=end,freq="M"))]
return date_list
@every(minutes=24 * 60)
def on_start(self):
# 我須要生成201101~201812的全部連接
date_list = self.get_date_list("2011-01-01","2019-01-01")
for item in date_list:
self.crawl('http://lishi.tianqi.com/%s/%s.html' %(self._city,item) , callback=self.index_page)
@config(age=10 * 24 * 60 * 60)
def index_page(self, response):
items = []
for each in response.doc('.tqtongji2 > ul:not(.t1)').items():
date = each("li:eq(0)").text()
hot = each("li:eq(1)").text()
cold = each("li:eq(2)").text()
weather = each("li:eq(3)").text()
wind_direction = each("li:eq(4)").text()
wind_power = each("li:eq(5)").text()
item = {
"date":date,
"hot":hot,
"cold":cold,
"weather":weather,
"wind_direction":wind_direction,
"wind_power":wind_power}
items.append(item)
return items
複製代碼
首先看一下數據的基本面excel
excel 讀取
def read_xlsx():
df = pd.read_excel("天氣數據.xlsx",names =["cold","date","hot","weather","wind","wind_s"])
return df
複製代碼
我要知道,三亞天氣的一個走勢,這個地方直接按照時間進行圖標製做吧
按照時間排序
df = read_xlsx()
opt_df = df[['date','cold','hot']]
opt_df = opt_df.sort_values(by='date')
複製代碼
能夠明顯的看到波峯和波谷,這個地方只能知道三亞的天氣是有波動的,距離我獲得最後的結果進了一點點
按照單獨的一年繪製,獲得一個很混亂的圖,仍是沒有獲得我想要的結果opt_df = opt_df.set_index("date")
for i in range(2011,2019):
data = opt_df[str(i)]
plt.plot(range(1,len(data)+1), data['cold'])
plt.show()
複製代碼
每一個顏色表示不一樣的年分,看來仍是要用子圖了。
從上到下,我從2011年依次羅列到2018年opt_df = opt_df.set_index("date")
for i in range(2011,2019):
data = opt_df[str(i)]
plt.subplot(8,1,i-2010)
plt.grid(True)
plt.plot(range(1,len(data)+1), data['cold'])
plt.plot(range(1, len(data) + 1), data['hot'])
plt.title(str(i)+u"年,溫度曲線")
plt.tight_layout()
plt.savefig("filename.png")
plt.show()
複製代碼
一個小的注意事項是:解決使用 plt.savefig 保存圖片時一片空白
緣由
其實產生這個現象的緣由很簡單:在 plt.show() 後調用了 plt.savefig() ,在 plt.show() 後實際上已經建立了一個新的空白的圖片(座標軸),這時候你再 plt.savefig() 就會保存這個新生成的空白圖片。
知道了緣由,就不難知道解決辦法了,解決辦法有兩種:
在 plt.show() 以前調用 plt.savefig();
import matplotlib.pyplot as plt
""" 一些畫圖代碼 """
plt.savefig("filename.png")
plt.show()
複製代碼
畫圖的時候獲取當前圖像(這一點很是相似於 Matlab 的句柄的概念):
# gcf: Get Current Figure
fig = plt.gcf()
plt.show()
fig1.savefig('tessstttyyy.png', dpi=100)
複製代碼
細細的看了一下,發現好穩定。。。。走勢變化不大,那麼,在去細化,咱們拆解2018年的,而後推斷2019年的,這個地方須要的展現12個月份的天氣了,代碼走起。
d2018 = opt_df["2018"]
print(d2018)
for i in range(1,13):
data = opt_df["2018-"+str(i)]
plt.subplot(12, 1, i)
plt.grid(True)
plt.plot(range(1, len(data) + 1), data['cold'])
plt.plot(range(1, len(data) + 1), data['hot'])
plt.title(str(i) + u"月,溫度曲線")
plt.yticks([0,5,10,15,20,25,30,35,40])
plt.xticks(range(1,32))
plt.tight_layout()
plt.savefig("filename.png")
plt.show()
複製代碼
哈哈,到如今爲止,啥也沒看出來
繼續努力,看平均天氣,把2018年每月的平均天氣整理出來
月份 | 最低氣溫 | 最高氣溫 |
---|---|---|
1 | 20.1 | 26.1 |
2 | 17.6 | 26.6 |
3 | 19.6 | 29.3 |
4 | 22.0 | 30.7 |
6 | 25.2 | 32.5 |
7 | 24.5 | 31.4 |
8 | 24.5 | 31.8 |
9 | 25.2 | 31.9 |
10 | 23.2 | 31.5 |
11 | 21.7 | 30.2 |
12 | 20.4 | 28.1 |
哈哈哈,都是好天氣......我到底在作啥結果.....
受不了,我去百度了,看看天氣網站的結論,emmm....同樣,在咱們河北人看來,這就是恆溫的。 我還有的分析,個人數據是這樣子的 是否下雨,我能夠統計一下,代碼走起來 整年的天氣天氣 | 天數 |
---|---|
中雨 | 15 |
多雲 | 176 |
大雨 | 5 |
小雨 | 5 |
晴 | 12 |
暴雨 | 1 |
陰 | 11 |
陣雨 | 38 |
雷陣雨 | 6 |
統計一下每月的天氣變化
總結,兩個結論,666好吧,中止了,好像沒獲得啥數據,就是1月,2月,3月,11月,12月去三亞吧,這幾個月份中3月份和11月份機票最便宜,看來我要寫爬取機票的博客了