用urllib爬取鏈家北京地區所有小區的戶型圖
#__author:'Mr.Li'
#date:2018/8/3
from urllib import request
import ssl
ssl._create_default_https_context = ssl._create_unverified_context
import re
from lxml import etree
import os
import time
base_url = 'https://bj.lianjia.com/xiaoqu/'
headers = {
'user-agent':'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/67.0.3396.79 Safari/537.36',
'cookie':'lianjia_uuid=18cb131e-a8e3-41bf-8e86-507edee0f299; _smt_uid=5b62bc8c.251b3200; UM_distinctid=164f9b084f25ea-00f5ad1d6d5297-444a022e-100200-164f9b084f365c; _ga=GA1.2.1413848736.1533197464; ljref=pc_sem_baidu_ppzq_x; select_city=110000; all-lj=3d8def84426f51ac8062bdea518a8717; lianjia_ssid=dded298d-1768-473f-af50-f914a5193f3b; TY_SESSION_ID=e187b4fb-9292-4c21-ab3c-bd029576b734; Hm_lvt_9152f8221cb6243a53c83b956842be8a=1533197452,1533448890; CNZZDATA1253477573=863897098-1533192835-https%253A%252F%252Fwww.baidu.com%252F%7C1533447325; CNZZDATA1254525948=637059447-1533196463-https%253A%252F%252Fwww.baidu.com%252F%7C1533446989; CNZZDATA1255633284=1930881136-1533192406-https%253A%252F%252Fwww.baidu.com%252F%7C1533448412; CNZZDATA1255604082=899166655-1533193317-https%253A%252F%252Fwww.baidu.com%252F%7C1533446645; _jzqa=1.506542567139101800.1533197453.1533197453.1533448891.2; _jzqc=1; _jzqy=1.1533197453.1533448891.2.jzqsr=baidu|jzqct=%E9%93%BE%E5%AE%B6%E7%BD%91.jzqsr=baidu|jzqct=%E9%93%BE%E5%AE%B6; _jzqckmp=1; _qzjc=1; Hm_lpvt_9152f8221cb6243a53c83b956842be8a=1533448893; _qzja=1.583906513.1533197452708.1533197452708.1533448891165.1533448891165.1533448892836.0.0.0.3.2; _qzjb=1.1533448891164.2.0.0.0; _qzjto=2.1.0; _jzqb=1.2.10.1533448891.1; _gid=GA1.2.1293286786.1533448894; _gat=1; _gat_past=1; _gat_global=1; _gat_new_global=1; _gat_dianpu_agent=1'
}
req = request.Request(base_url,headers=headers)
response = request.urlopen(req)
# 主頁,裡面有各個區的名字
html = response.read().decode('utf-8')
html = etree.HTML(html)
# 提取出來各個區的連結
res = html.xpath('//div[@data-role="ershoufang"]/div/a/@href')
# print(res)
for url in res:
# print(url)
if url == 'https://lf.lianjia.com/xiaoqu/yanjiao/':
# print(url)
# url1 = 'https://bj.lianjia.com' + url
# 得到香河區的連結
# print(url)
req = request.Request(url,headers=headers)
response = request.urlopen(req)
# 得出各個區的小區的列表
html = response.read().decode('utf-8')
pattern = re.compile(r'page-box house-lst-page-box.*?totalPage":(.*?),.*?</div>', re.S)
page = pattern.findall(html)
# page是指一共有多少頁小區
page = int(page[0])
fullurl = url + 'pg%d'
# print(fullurl)
for i in range(1, page + 1, 1):
fullurl = url + 'pg%d'
fullurl = fullurl % i
# print(fullurl)
req = request.Request(fullurl, headers=headers)
response = request.urlopen(req)
html = response.read().decode('utf-8')
html = etree.HTML(html)
# 各個小區的連結
res = html.xpath('//ul[@class="listContent"]//a[@class="img"]/@href')
# print(res)
for i in res:
req = request.Request(i, headers=headers)
response = request.urlopen(req)
# 獲取小區詳情頁
html = response.read().decode('utf-8')
# print(html)
# 獲取全部成交的連結
pattern = re.compile(r'class="frameDeal".*?<a href="(.*?)" .*?">.*?</a>', re.S)
href = pattern.findall(html)
# print(href)
# 有些小區是沒有全部成交的連結,所以要排除是空的
if href != []:
res = href[0]
# print(res)
last = request.Request(res, headers=headers)
resp = request.urlopen(last)
h = resp.read().decode('utf-8')
# print(h)
pattern = re.compile(r'class="listContent">.*?class="title".*?href="(.*?)" target="_blank">', re.S)
page = pattern.findall(h)
pag = page[0]
# 拿到全部成交記錄的連結
# print(pag)
if pag != '<%=fangjia_url%>" class="unitPrice':
r = request.Request(pag,headers=headers)
htm = request.urlopen(r)
respo = htm.read().decode('utf-8')
# print(respo)
pat = re.compile(r'<li data-src=".*?" data-desc="戶型圖"><img src="(.*?)" alt="">',re.S)
photo = pat.findall(respo)
# print(photo)
patt= re.compile(r'class="wrapper">.*?class="index_h1">(.*?)</h1>')
name = patt.findall(respo)
name = name[0]
# 獲取儲存圖片的時候圖片的名字
if photo != []:
photo = photo[0]
img_name = photo.split('/')
print(name,img_name[-1])
# 自動建立目錄
path = os.path.join('./huxing/', name)
if not os.path.exists(path):
os.mkdir(path)
# with open(path,'wb') as f:
# f.write(img)
# 下載圖片
if img_name[1] not in path:
request.urlretrieve(photo, os.path.join(path, img_name[-1]))
time.sleep(3)
相關文章
- 用python爬取鏈家的租房資訊Python
- 國家網路安全產業園區落戶北京產業
- Python爬取網頁的所有內外鏈Python網頁
- 小區防疫地圖看板,哪裡可以繪製防疫地圖?地圖
- python爬蟲--爬取鏈家租房資訊Python爬蟲
- 區塊鏈的幾個小故事.小白學區塊鏈01區塊鏈
- 區塊鏈未來應用藍圖區塊鏈
- 爬取行政區劃程式碼
- 用Python爬取新型冠狀病毒肺炎實時資料,pyecharts v1.x繪製省市區疫情地圖PythonEcharts地圖
- 用 Python 構建一個極小的區塊鏈Python區塊鏈
- 地圖小區景點邊界輪廓實現地圖
- 技術工坊|區塊鏈應用場景暢想(北京)區塊鏈
- 區塊鏈101:區塊鏈的應用和用例是什麼?區塊鏈
- 新人必讀:區塊鏈實用型技能樹區塊鏈
- 百度地圖獲取多行政區域圍欄地圖
- 區塊鏈DAPP的小知識區塊鏈APP
- 區塊鏈技術開發主鏈區塊鏈的應用分析區塊鏈
- 小區確診病例實時地圖,怎麼繪製疫情視覺化地圖?地圖視覺化
- 區塊鏈溯源落地應用,區塊鏈在商品溯源中的應用區塊鏈
- 用Python爬取WordPress官網所有外掛Python
- 如何給廠區做導航地圖?科技園區導航地圖服務地圖
- 小圖示區域的部分
- 初識區塊鏈 - 用JS構建你自己的區塊鏈區塊鏈JS
- 區塊鏈開發公司談區塊鏈的應用場景區塊鏈
- 基於三維地圖的智慧園區視覺化解決方案,用於智慧園區的導航地圖怎麼繪製?地圖視覺化
- 區塊鏈應用|人工智慧的落地及區塊鏈應用暢想區塊鏈人工智慧
- 高德地圖首席科學家任小楓:視覺智慧在高德地圖的應用地圖視覺
- 圖解區塊鏈:14張圖看懂什麼是“區塊鏈技術”?圖解區塊鏈
- 智慧園區視覺化地圖製作,如何做一個園區的導航地圖?視覺化地圖
- 區塊鏈應用|最全區塊鏈生態圖譜釋出,一張圖看清2400個典型專案區塊鏈
- 【北京望京】Contentbox招聘golang、區塊鏈工程師Golang區塊鏈工程師
- 區塊鏈公司談區塊鏈技術最新應用區塊鏈
- 區塊鏈特徵與區塊鏈技術應用落地區塊鏈特徵
- 安全快報 | 專家警告:小政府國家、地區更易受勒索軟體襲擊
- 【爬蟲】利用Python爬蟲爬取小麥苗itpub部落格的所有文章的連線地址(1)爬蟲Python
- 區塊鏈的發展,時代轉變下的區塊鏈應用區塊鏈
- 區塊鏈技術公司 區塊鏈的應用場景思路剖析區塊鏈
- 雲+區塊鏈 實現區塊鏈技術的普惠應用區塊鏈