成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

100行代碼爬取全國所有必勝客餐廳信息

開發 后端 數據分析
數據分析的前提是有數據可分析。如果沒有數據怎么辦?一是可以去一些數據網站下載相關的數據,不過數據內容可能不是自己想要的。二是自己爬取一些網站數據。今天,我就爬取全國各地所有的必勝客餐廳信息,以便后續做數據分析。

當我剛接觸 Python 時,我已經被 Python 深深所吸引。Python 吸引我的地方不僅僅能用其編寫網絡爬蟲,而且能用于數據分析。我能將大量的數據中以圖形化方式呈現出來,更加直觀的解讀數據。

數據分析的前提是有數據可分析。如果沒有數據怎么辦?一是可以去一些數據網站下載相關的數據,不過數據內容可能不是自己想要的。二是自己爬取一些網站數據。

今天,我就爬取全國各地所有的必勝客餐廳信息,以便后續做數據分析。

01抓取目標

我們要爬取的目標是必勝客中國。打開必勝客中國首頁,進入“餐廳查詢”頁面。

100行代碼爬取全國所有必勝客餐廳信息

我們要爬取的數據內容有城市、餐廳名字、餐廳地址以及餐廳聯系電話。因為我看到頁面中有地圖,所以頁面一定有餐廳地址的經緯度。因此,餐廳的經緯度也是我們需要爬取的數據。

至于全國有必勝客餐廳的城市列表,我們可以通過頁面的“切換城市”獲取。

100行代碼爬取全國所有必勝客餐廳信息

02分析目頁面

在編寫爬蟲程序之前,我都是先對頁面進行簡單分析,然后指定爬取思路。而且對頁面結構進行分析往往會有一些意想不到的收獲。

我們使用瀏覽器的開發者工具對頁面結構進行簡單分析。

100行代碼爬取全國所有必勝客餐廳信息

我們在 StoreList 頁面中能找到我們所需的數據。這個能確定數據提取的 Xpath 語法。

StoreList 頁面的 Response 內容比較長。我們先不著急關閉頁面,往下看看,找找看是否有其他可利用的內容。***,我們找到調用獲取餐廳列表信息的 JavaScript 函數代碼。

100行代碼爬取全國所有必勝客餐廳信息

我們接著搜索下GetStoreList函數,看看瀏覽器如何獲取餐廳列表信息的。

100行代碼爬取全國所有必勝客餐廳信息

從代碼中,我們可以了解到頁面使用 Ajax 方式來獲取數據。頁面以 POST 方式請求地址http://www.pizzahut.com.cn/StoreList/Index。同時,請求還攜帶參數 pageIndex 和 pageSize。

03爬取思路

經過一番頁面結構分析之后,我們指定爬取思路。首先,我們先獲取城市信息。然后將其作為參數,構建 HTTP 請求訪問必勝客服務器來獲取當前城市中所有餐廳數據。

為了方便數據爬取,我將所有城市全部寫入到 cities.txt 中。等要爬取數據時,我們再從文件中讀取城市信息。

爬取思路看起來沒有錯,但是還是有個難題沒有搞定。我們每次打開必勝客的官網,頁面每次都會自動定位到我們所在的城市。如果無法破解城市定位問題,我們只能抓取一個城市數據。

于是乎,我們再次瀏覽首頁,看看能不能找到一些可用的信息。最終,我們發現頁面的 cookies 中有個 iplocation 字段。我將其進行 Url 解碼,得到 深圳|0|0 這樣的信息。

100行代碼爬取全國所有必勝客餐廳信息

看到這信息,我恍然大悟。原來必勝客網站根據我們的 IP 地址來設置初始城市信息。如果我們能偽造出 iplocation 字段信息,那就可以隨便修改城市了。

04代碼實現

***步是從文件中讀取城市信息。

 

  1. # 全國有必勝客餐廳的城市, 我將城市放到文件中, 一共 380 個城市 
  2. cities = [] 
  3.  
  4. def get_cities(): 
  5.     """ 從文件中獲取城市 """  file_name = 'cities.txt' 
  6.   with open(file_name, 'r', encoding='UTF-8-sig'as file: 
  7.         for line in file: 
  8.             city = line.replace(' 
  9. ', '') 
  10.             cities.append(city) 

第二步是依次遍歷 cities 列表,將每個城市作為參數,構造 Cookies 的 iplocation 字段。

  1. # 依次遍歷所有城市的餐廳 
  2. for city in cities: 
  3.     restaurants = get_stores(city, count
  4.     results[city] = restaurants 
  5.     count += 1 
  6.   time.sleep(2) 

然后,我們再以 POST 方式攜帶 Cookie 去請求必勝客服務器。***再對返回頁面數據進行提取。

  1. def get_stores(city, count): 
  2.     """ 根據城市獲取餐廳信息 """ 
  3.     session = requests.Session() 
  4.     # 對【城市|0|0】進行 Url 編碼 
  5.     city_urlencode = quote(city + '|0|0'
  6.     # 用來存儲首頁的 cookies 
  7.     cookies = requests.cookies.RequestsCookieJar() 
  8.  
  9.     headers = { 
  10.         'User-agent''Mozilla/5.0 (Windows NT 6.3; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/55.0.2883.87 UBrowser/6.2.3964.2 Safari/537.36'
  11.         'accept''text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8'
  12.         'Host''www.pizzahut.com.cn'
  13.         'Cache-Control''max-age=0'
  14.         'Connection''keep-alive'
  15.     } 
  16.  
  17.     print('============第'count'個城市:', city, '============'
  18.     resp_from_index = session.get('http://www.pizzahut.com.cn/', headers=headers) 
  19.     # print(resp_from_index.cookies) 
  20.     # 然后將原來 cookies 的 iplocation 字段,設置自己想要抓取城市。 
  21.     cookies.set('AlteonP', resp_from_index.cookies['AlteonP'], domain='www.pizzahut.com.cn'
  22.     cookies.set('iplocation', city_urlencode, domain='www.pizzahut.com.cn'
  23.     # print(cookies) 
  24.  
  25.     page = 1 
  26.     restaurants = [] 
  27.  
  28.     while True
  29.         data = { 
  30.             'pageIndex': page, 
  31.             'pageSize'"50"
  32.         } 
  33.  
  34.         response = session.post('http://www.pizzahut.com.cn/StoreList/Index', headers=headers, data=data, cookies=cookies) 
  35.         html = etree.HTML(response.text) 
  36.         # 獲取餐廳列表所在的 div 標簽 
  37.         divs = html.xpath("//div[@class='re_RNew']"
  38.         temp_items = [] 
  39.         for div in divs: 
  40.             item = {} 
  41.             content = div.xpath('./@onclick')[0] 
  42.             # ClickStore('22.538912,114.09803|城市廣場|深南中路中信城市廣場二樓|0755-25942012','GZH519'
  43.             # 過濾掉括號和后面的內容 
  44.             content = content.split('('')[1].split(')')[0].split('','')[0] 
  45.  
  46.             if len(content.split('|')) == 4: 
  47.                 item['coordinate'] = content.split('|')[0] 
  48.                 item['restaurant_name'] = content.split('|')[1] + '餐廳' 
  49.                 item['address'] = content.split('|')[2] 
  50.                 item['phone'] = content.split('|')[3] 
  51.             else
  52.                 item['restaurant_name'] = content.split('|')[0] + '餐廳' 
  53.                 item['address'] = content.split('|')[1] 
  54.                 item['phone'] = content.split('|')[2] 
  55.             print(item) 
  56.             temp_items.append(item) 
  57.  
  58.         if not temp_items: 
  59.             break 
  60.         restaurants += temp_items 
  61.         page += 1 
  62.         time.sleep(5) 
  63.     return restaurants 

第三步是將城市以及城市所有餐廳信息等數據寫到 Json 文件中。

  1. with open('results.json''w', encoding='UTF-8'as file: 
  2.     file.write(json.dumps(results, indent=4, ensure_ascii=False)) 

05爬取結果

程序運行完之后, 就會在當前目錄下生成一個名為「results.json」文件。完整代碼請見GitHub:

https://github.com/monkey-soft/SchweizerMesser/tree/master/Pizzahut

100行代碼爬取全國所有必勝客餐廳信息

關于作者:極客猴,熱衷于 Python,目前擅長利用 Python 制作網絡爬蟲以及 Django 框架。

責任編輯:未麗燕 來源: Python中文社區
相關推薦

2018-12-10 15:53:41

Python必勝客數據分析

2023-04-11 22:03:36

2017-08-01 17:02:19

代碼Python數據

2025-05-22 07:40:32

2023-05-04 07:34:37

Rust代碼CPU

2021-12-16 06:21:16

React組件前端

2017-02-08 14:16:17

C代碼終端

2017-11-17 19:56:46

爬蟲視頻信息數據庫

2018-01-10 22:19:44

2020-08-21 13:40:17

Python代碼人體膚色

2023-11-27 07:10:06

日志中間件

2020-03-26 12:38:15

代碼節點數據

2015-02-09 10:43:00

JavaScript

2019-05-05 09:46:01

Python代碼神經網絡

2020-12-07 10:59:01

Python數據工具

2015-09-01 16:26:18

Linux內核

2020-07-20 09:20:48

代碼geventPython

2023-02-01 22:40:38

shellDocker

2010-09-02 12:30:40

2013-09-09 10:52:10

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 日韩视频国产 | 欧美国产亚洲一区二区 | 一区二区视频在线 | 成人中文字幕在线 | 国产亚洲欧美日韩精品一区二区三区 | 欧美激情一区二区 | 一级毛片黄片 | 亚洲一区二区三区免费在线观看 | 成人av一区二区三区 | 亚洲交性 | 韩日视频在线观看 | 99免费视频 | 久久久久精 | 久久久久久综合 | 精品视频一区二区三区 | 国产精品久久久久久妇女6080 | 免费在线观看成人 | 一区二区三区国产精品 | 亚洲视频在线观看 | 成年网站在线观看 | 国产高清免费 | 欧美在线观看一区 | 一区二区国产在线观看 | 国产高清美女一级a毛片久久w | 国户精品久久久久久久久久久不卡 | 久久精品亚洲 | 色婷婷av99xx | 视频第一区 | wwww.8888久久爱站网 | 天天干夜夜操 | 亚洲精品一区中文字幕乱码 | 一区二区三区成人 | 久久精品免费 | 桃花av在线 | 国产一级电影网 | 中文字幕电影在线观看 | 欧美一区二区在线播放 | 永久精品 | 久久精品无码一区二区三区 | 在线成人免费观看 | 国产精品久久久久一区二区三区 |