91精品人妻系列动画无码 - 国产精品夜间视频香蕉 - 91丝袜人妻一区二区三区 - 久久伊伊香蕉精品网站

信盈達(dá)—您身邊的嵌入式&人工智能專家
全國(guó)免費(fèi)咨詢熱線:400-8788-909
您現(xiàn)在的位置在: 首頁(yè)> 學(xué)習(xí)經(jīng)驗(yàn)>

時(shí)間:2019-05-25 00:00:00 來(lái)源:信盈達(dá) 作者:信盈達(dá)

tica, Verdana, Tahoma, sans-serif">  在一些網(wǎng)站上經(jīng)??吹揭恍┖玫膱D片希望批量下載保存到本地,但是一個(gè)個(gè)右擊保存有顯的十分麻煩,這里可以通過python 來(lái)實(shí)現(xiàn)這樣一個(gè)簡(jiǎn)單的爬蟲功能,把我們想要的代碼爬取到本地,功能有點(diǎn)類似我們之前學(xué)過的批處理。下面就看看如何使用python來(lái)實(shí)現(xiàn)這樣一個(gè)功能,主要分為三步,如下:
一. 獲取整個(gè)頁(yè)面數(shù)據(jù)
首先我們可以先獲取要下載圖片的整個(gè)頁(yè)面信息。
創(chuàng)建getjpg.py文件
  1. #coding=utf-8
  2. import urllib

  3. def getHtml(url):
  4.     page = urllib.urlopen(url)
  5.     html = page.read()
  6.     return html

  7. html = getHtml("http://tieba.baidu.com/p/2738151262")

  8. print html
復(fù)制代碼

說明:
  Urllib 模塊提供了讀取web頁(yè)面數(shù)據(jù)的接口,我們可以像讀取本地文件一樣讀取www和ftp上的數(shù)據(jù)。
首先,我們定義了一個(gè)getHtml()函數(shù);
urllib.urlopen()方法用于打開一個(gè)URL地址;
read()方法用于讀取URL上的數(shù)據(jù);
向getHtml()函數(shù)傳遞一個(gè)網(wǎng)址,并把整個(gè)頁(yè)面下載下來(lái)。執(zhí)行程序就會(huì)把整個(gè)網(wǎng)頁(yè)打印輸出。
二. 篩選頁(yè)面中想要的數(shù)據(jù)

 Python 提供了非常強(qiáng)大的正則表達(dá)式,我們需要先要了解一點(diǎn)python 正則表達(dá)式的知識(shí)才行。
re模塊中一些重要的函數(shù):
假如我們百度貼吧找到了幾張漂亮的壁紙,通過到前段查看工具。找到了圖片的地址,如:src="http://imgsrc.baidu.com/forum/w%3D580/sign=750661a0fcfaaf5184e381b7bc5594ed/75fafbedab64034fc3ed0b80aec379310a551d11.jpg"
修改代碼如下:
  1. import re
  2. import urllib

  3. def getHtml(url):
  4.     page = urllib.urlopen(url)
  5.     html = page.read()
  6.     return html

  7. def getImg(html):
  8.     reg = r'src="(.+?\.jpg)" pic_ext'
  9.     imgre = re.compile(reg)
  10.     imglist = re.findall(imgre,html)
  11.     return imglist      
  12.    
  13. html = getHtml("http://tieba.baidu.com/p/2460150866")
  14. print getImg(html)
復(fù)制代碼

我們又創(chuàng)建了getImg()函數(shù),用于在獲取的整個(gè)頁(yè)面中篩選需要的圖片連接。re模塊主要包含了正則表達(dá)式:
re.compile() 可以把正則表達(dá)式編譯成一個(gè)正則表達(dá)式對(duì)象.
re.findall() 方法讀取html 中包含 imgre(正則表達(dá)式)的數(shù)據(jù)。
運(yùn)行腳本將得到整個(gè)頁(yè)面中包含圖片的URL地址。
三. 將頁(yè)面篩選的數(shù)據(jù)保存到本地
把篩選的圖片地址通過for循環(huán)遍歷并保存到本地,代碼如下:
  1. #coding=utf-8
  2. import urllib
  3. import re

  4. def getHtml(url):
  5.     page = urllib.urlopen(url)
  6.     html = page.read()
  7.     return html

  8. def getImg(html):
  9.     reg = r'src="(.+?\.jpg)" pic_ext'
  10.     imgre = re.compile(reg)
  11.     imglist = re.findall(imgre,html)
  12.     x = 0
  13.     for imgurl in imglist:
  14.         urllib.urlretrieve(imgurl,'c:\Users\Administrator\Desktop\pic\%s.jpg'  % x)
  15.         x+=1


  16. html = getHtml("http://tieba.baidu.com/p/2460150866")

  17. print getImg(html)
復(fù)制代碼

這里的核心是用到了urllib.urlretrieve()方法,直接將遠(yuǎn)程數(shù)據(jù)下載到本地。
通過一個(gè)for循環(huán)對(duì)獲取的圖片連接進(jìn)行遍歷,為了使圖片的文件名看上去更規(guī)范,對(duì)其進(jìn)行重命名,命名規(guī)則通過x變量加1。保存的位置默認(rèn)為程序的存放目錄。
程序運(yùn)行完成,將在目錄下看到下載到本地的文件。
效果如下:
  • 上一篇:
  • 下一篇: