国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

Python 制作查詢商品歷史價格的小工具

瀏覽:5日期:2022-07-07 17:08:49

一年一度的雙十一就快到了,各種砍價、蓋樓、挖現金的口令將在未來一個月內充斥朋友圈、微信群中。玩過多次雙十一活動的小編表示一頓操作猛如虎,一看結果2毛5。浪費時間不說而且未必得到真正的優惠,雙十一電商的“明降暗升”已經是默認的潛規則了。打破這種規則很簡單,可以用 Python 寫一個定時監控商品價格的小工具。

Python 制作查詢商品歷史價格的小工具

思路

第一步抓取商品的價格存入 Python 自帶的 SQLite 數據庫 每天定時抓取商品價格 使用 pyecharts 模塊繪制價格折線圖,讓低價一目了然

抓取京東價格

從商品詳情的頁面中打開 F12 控制面板,找到包含 p.3 的鏈接,在旁邊的 preview 面板中可以看到當前商品價格

Python 制作查詢商品歷史價格的小工具

def get_jd_price(skuId): sku_detail_url = ’http://item.jd.com/{}.html’ sku_price_url = ’https://p.3.cn/prices/get?type=1&skuid=J_{}’ r = requests.get(sku_detail_url.format(skuId)).content soup = BeautifulSoup(r, ’html.parser’, from_encoding=’utf-8’) sku_name_div = soup.find(’div’, class_='sku-name') if not sku_name_div: print(’您輸入的商品ID有誤!’) return else: sku_name = sku_name_div.text.strip() r = requests.get(sku_price_url.format(skuId)) price = json.loads(r.text)[0][’p’] data = { ’sku_id’: skuId, ’sku_name’: sku_name, ’price’: price } return data

把抓取的價格存入 sqlite 數據庫,使用 PyCharm 的 Database 功能創建一個 sqlite 數據庫

Python 制作查詢商品歷史價格的小工具

Python 制作查詢商品歷史價格的小工具

最終將數據插入到數據庫

# 新增def insert(data): conn = sqlite3.connect(’price.db’) c = conn.cursor() sql = ’INSERT INTO price (sku_id,sku_name,price) VALUES ('{}', '{}', '{}')’.format(data.get('sku_id'), data.get('sku_name'), data.get(’price’) ) c.execute(sql) conn.commit() conn.close()# 查詢def select(sku_id): conn = sqlite3.connect(’price.db’) c = conn.cursor() sql = ’select sku_id, sku_name, price, time from price where sku_id = '{}' order by time asc’.format(sku_id) cursor = c.execute(sql) datas = [] for row in cursor: data = { ’sku_id’: row[0], ’sku_name’: row[1], ’price’: row[2], ’time’: row[3] } datas.append(data) conn.close() return datas

示例結果

Python 制作查詢商品歷史價格的小工具

計劃任務

使用輕量級的 schedule 模塊每天早上 10 點抓取京東價格這一步驟

安裝 schedule 模塊

pip install schedule

def run_price_job(skuId): # 使用不占主線程的方式啟動 計劃任務 def run_continuously(interval=1): cease_continuous_run = threading.Event() class ScheduleThread(threading.Thread): @classmethod def run(cls):while not cease_continuous_run.is_set(): schedule.run_pending() time.sleep(interval) continuous_thread = ScheduleThread() continuous_thread.start() return cease_continuous_run # 每天10點運行,get_jd_price:任務方法,skuId:任務方法的參數 schedule.every().day.at('10:00').do(get_jd_price, skuId=skuId) run_continuously()

查看歷史價格

使用 pytharts 模塊繪制折線圖,直觀的查看每一天的價格差異

datas = select(skuId)def line(datas): x_data = [] y_data = [] for data in datas: x_data.append(data.get(’time’)) y_data.append(data.get(’price’)) ( Line() .add_xaxis(x_data) .add_yaxis(datas[0].get(’sku_name’), y_data, is_connect_nones=True) .render('商品歷史價格.html') )

Python 制作查詢商品歷史價格的小工具

總結

本文抓取了京東商城的價格,小伙伴們也可以修個腳本抓取淘寶的價格。使用 Python 解決生活中的小小痛點,讓錢包不再干癟。

示例代碼:

用 Python 制作商品歷史價格查詢

以上就是Python 制作查詢商品歷史價格的小工具的詳細內容,更多關于python 查詢歷史價格的資料請關注好吧啦網其它相關文章!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: www.成年人| 狠久久| a级黄色毛片免费播放视频 a级精品九九九大片免费看 | 成人伊人青草久久综合网 | 欧美色老头oldvideos | 日日摸人人看97人人澡 | 在线视频观看免费视频18 | 日韩视频免费一区二区三区 | 日韩一区二区不卡 | 精品热线九九精品视频 | 亚洲欧美精品一区二区 | 国产高清一区二区三区 | 午夜精品久视频在线观看 | 成人18网址在线观看 | 92av在线 | 国产精品自拍一区 | 国产成人综合怡春院精品 | 91成人免费视频 | 国产深夜福利在线观看网站 | 欧美成本人视频 | 国产午夜三区视频在线 | 久久亚洲精品中文字幕 | 日本人视频网站一 | 一区二区在线播放福利视频 | 依依成人综合网 | 日本三级香港三级人妇99 | 性感美女一级毛片 | 波多野结衣中文一区二区免费 | 一区二区三区在线 | 2020久久国产最新免费观看 | 美女张开腿让男人桶爽免 | 亚洲精品在线视频观看 | 精品国产不卡一区二区三区 | 欧美在线观看一区二区 | 荡公乱妇蒂芙尼中文字幕 | 国产高清免费观看 | 黄录像欧美片在线观看 | 成人在线观看网址 | 欧美性色生活免费观看 | 亚洲成在人 | dy888午夜国产午夜精品 |