本人長期出售超大量微博數(shù)據(jù)、旅游網(wǎng)站評論數(shù)據(jù),并提供各種指定數(shù)據(jù)爬取服務(wù),Message to YuboonaZhang@Yahoo.com。同時(shí)歡迎加入社交媒體數(shù)據(jù)交流群:99918768
青州網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)公司!從網(wǎng)頁設(shè)計(jì)、網(wǎng)站建設(shè)、微信開發(fā)、APP開發(fā)、成都響應(yīng)式網(wǎng)站建設(shè)公司等網(wǎng)站項(xiàng)目制作,到程序開發(fā),運(yùn)營維護(hù)。創(chuàng)新互聯(lián)公司公司2013年成立到現(xiàn)在10年的時(shí)間,我們擁有了豐富的建站經(jīng)驗(yàn)和運(yùn)維經(jīng)驗(yàn),來保證我們的工作的順利進(jìn)行。專注于網(wǎng)站建設(shè)就選創(chuàng)新互聯(lián)公司。
最近在做機(jī)器學(xué)習(xí)下的人臉識(shí)別的學(xué)習(xí),機(jī)器學(xué)習(xí)這個(gè)東西有點(diǎn)暴力,很大程度上靠訓(xùn)練的數(shù)據(jù)量來決定效果。為了找數(shù)據(jù),通過一個(gè)博客的指導(dǎo),瀏覽了幾個(gè)很知名的數(shù)據(jù)集。
幾個(gè)大型數(shù)據(jù)集是通過發(fā)郵件申請進(jìn)行下載,幾個(gè)小型數(shù)據(jù)集直接在網(wǎng)頁的鏈接下載,還有一個(gè)Pubfig數(shù)據(jù)集則是提供了大量圖片的鏈接來讓我們自己寫程序來下載。
權(quán)衡了數(shù)據(jù)量的需求,最后選擇Pubfig的數(shù)據(jù)集,于是就自己寫了一個(gè)python圖片采集程序,里面用了urllib和requests兩種方法.
這個(gè)數(shù)據(jù)文件提供了在數(shù)據(jù)集中出現(xiàn)的所有人物
這個(gè)數(shù)據(jù)文件提供了每個(gè)人的urls
可以看出來這個(gè)數(shù)據(jù)集的處理其實(shí)非常簡單了,可以通過readlines的方式存進(jìn)列表用空格分開一下數(shù)據(jù)就可以把urls提取出來了。
urls在文件的中后部,寫個(gè)文件把它單純地提取出來,方便使用。
我單獨(dú)把Miley_Cyrus的部分提取出來放了一個(gè)txt文件
pic_url = []
with open('./Miley_Cyrus.txt') as f:
for i in f.readlines():
pic_url.append(i.strip('\r\n'))
urls = []
for s in pic_url:
_, _, _, url, _, _ = s.split()
urls.append(url)
# 寫入到文件里面
with open('url.data', 'w') as f:
for i in urls:
f.write(i)
f.write('\n')
import urllib.request as request
import socket
import os
# 在同級(jí)目錄新建文件夾存圖片
os.mkdir('./img')
# 為請求增加一下頭
user_agent = 'Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/62.0.3202.62 Safari/537.36'
headers = ('User-Agent', user_agent)
opener = request.build_opener()
opener.addheaders = [headers]
request.install_opener(opener)
# 設(shè)定一下無響應(yīng)時(shí)間,防止有的壞圖片長時(shí)間沒辦法下載下來
timeout = 20
socket.setdefaulttimeout(timeout)
# 從文件里面讀urls
urls = []
with open('./url.data') as f:
for i in f.readlines():
if i != '':
urls.append(i)
else:
pass
# 通過urllibs的requests獲取所有的圖片
count = 1
bad_url = []
for url in urls:
url.rstrip('\n')
print(url)
try:
pic = request.urlretrieve(url, './img3/%d.jpg' % count)
print('pic %d' % count)
count += 1
except Exception as e:
print(Exception, ':', e)
bad_url.append(url)
print('\n')
print('got all photos that can be got')
# 把沒有抓取到的urls保存起來
with open('bad_url3.data', 'w') as f:
for i in bad_url:
f.write(i)
f.write('\n')
print('saved bad urls')
import requests
import socket
import os
# 在同級(jí)目錄新建文件夾存圖片
os.mkdir('./img')
# 設(shè)定一下無響應(yīng)時(shí)間,防止有的壞圖片長時(shí)間沒辦法下載下來
timeout = 20
socket.setdefaulttimeout(timeout)
# 從文件里面讀urls
urls = []
with open('./url.data') as f:
for i in f.readlines():
if i != '':
urls.append(i)
else:
pass
# 為請求增加一下頭,獲取圖片
user_agent = 'Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/62.0.3202.62 Safari/537.36'
headers = {
'User-Agent': user_agent
}
bad_url = []
count = 1
for url in urls:
url.rstrip('\n')
print(url)
try:
pic = requests.get(url, headers=headers)
with open('./img2/%d.jpg' % count, 'wb') as f:
f.write(pic.content)
f.flush()
print('pic %d' % count)
count += 1
except Exception as e:
print(Exception, ':', e)
bad_url.append(url)
print('\n')
print('got all photos that can be got')
# 保存壞鏈接
with open('bad_url.data', 'w') as f:
for i in bad_url:
f.write(i)
f.write('\n')
print('saved bad urls')
8aoy1.cn