另一個(gè)Python3簡(jiǎn)單的爬取數(shù)據(jù)的實(shí)例(1688)

這個(gè)實(shí)例的函數(shù)主體和Python3簡(jiǎn)單的爬取淘寶數(shù)據(jù)一樣
就是目標(biāo)網(wǎng)站從淘寶更換成了1688(因?yàn)榘l(fā)現(xiàn)淘寶沒有原材料)

實(shí)現(xiàn)方式很簡(jiǎn)單,60行簡(jiǎn)單代碼就能實(shí)現(xiàn)
主要是python的包庫太過完善成翩,我根本不需要什么語法知識(shí)觅捆,直接調(diào)用現(xiàn)成的函數(shù)就行了
1688也沒有登陸訪問限制
cookies那部分就可以刪掉了

具體函數(shù)作用參照Python3簡(jiǎn)單的爬取淘寶數(shù)據(jù)

不同的地方在于他的編碼了url而不直接用漢字(話說編碼的網(wǎng)站更多吧)
噢,對(duì)爬到的頁面進(jìn)行的處理用bs4而不是正則
用的庫也有所不同

使用軟件

  • vscode
  • python3

用到的庫

urllib //處理url用的庫
requests //請(qǐng)求庫
xlwt //excel處理庫
bs4 //頁面內(nèi)容處理庫

整體代碼:

import urllib
import xlwt
from bs4 import BeautifulSoup
import requests

def writeExcel(ilt,name):
    if(name != ''):
        count = 0
        workbook = xlwt.Workbook(encoding= 'utf-8')
        worksheet = workbook.add_sheet('temp')
        worksheet.write(count,0,'序號(hào)')
        worksheet.write(count,1,'價(jià)格')
        worksheet.write(count,2,'名稱')
        for g in ilt:
            count = count + 1
            worksheet.write(count,0,count)
            worksheet.write(count,1,g[0])
            worksheet.write(count,2,g[1])
        workbook.save(name+'.xls')
        print('已保存為:'+name+'.xls')
    else:
        printGoodsList(ilt)

def getHTMLText(url):
    kv = {'user-agent':'Mozilla/5.0'}
    try:
        r = requests.get(url,headers=kv, timeout=30)
        r.raise_for_status()
        r.encoding = r.apparent_encoding
        return r.text
    except:
        return ""
     
def parsePage(ilt, html):
    try:
        bf = BeautifulSoup(html, 'html.parser')
        price = bf.find_all(attrs={'click-item':"price"})
        title = bf.find_all(attrs={'click-item':"title"})
        for i in range(len(price)):
            ilt.append([price[i].text,title[i].text])
    except:
        print("")
 
def printGoodsList(ilt):
    tplt = "{:4}\t{:8}\t{:16}"
    print(tplt.format("序號(hào)","價(jià)格", "名稱"))
    count = 0
    for g in ilt:
        count = count + 1
        print(tplt.format(count, g[0], g[1]))

def main():
    goods = input('搜索商品:')
    depth = int(input('搜索頁數(shù):'))
    name = input('輸入保存的excel名稱(留空print):')
    start_url = 'https://www.1688.com/chanpin/-.html?spm=a261b.2187593.searchbar.2.oUjRZK&keywords=' + urllib.parse.quote(goods,safe='/',encoding='gb2312')
    infoList = []
    print('處理中...')
    for i in range(depth):
        try:
            url = start_url + '&beginPage=' + str(i+1)
            html = getHTMLText(url)
            parsePage(infoList, html)
            print('第%i頁成功...' %(i+1))
        except:
            continue
    writeExcel(infoList,name)
    print('完成!')

main()

討論

很簡(jiǎn)單的小程序麻敌,回看淘寶好像這個(gè)更適合練手的樣子

還有很多要改進(jìn)的地方:

  • 用數(shù)據(jù)庫代替xlwt寫入excel(對(duì)于少量數(shù)據(jù)excel可能方便一點(diǎn)
  • 嘗試Xpath替代bs4(聽說xpath比bs4好用栅炒?
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市术羔,隨后出現(xiàn)的幾起案子赢赊,更是在濱河造成了極大的恐慌,老刑警劉巖级历,帶你破解...
    沈念sama閱讀 217,406評(píng)論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件释移,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡寥殖,警方通過查閱死者的電腦和手機(jī)玩讳,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,732評(píng)論 3 393
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來嚼贡,“玉大人锋边,你說我怎么就攤上這事”嗦” “怎么了豆巨?”我有些...
    開封第一講書人閱讀 163,711評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)掐场。 經(jīng)常有香客問我往扔,道長(zhǎng)贩猎,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,380評(píng)論 1 293
  • 正文 為了忘掉前任萍膛,我火速辦了婚禮吭服,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘蝗罗。我一直安慰自己艇棕,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,432評(píng)論 6 392
  • 文/花漫 我一把揭開白布串塑。 她就那樣靜靜地躺著沼琉,像睡著了一般。 火紅的嫁衣襯著肌膚如雪桩匪。 梳的紋絲不亂的頭發(fā)上打瘪,一...
    開封第一講書人閱讀 51,301評(píng)論 1 301
  • 那天,我揣著相機(jī)與錄音傻昙,去河邊找鬼闺骚。 笑死,一個(gè)胖子當(dāng)著我的面吹牛妆档,可吹牛的內(nèi)容都是我干的僻爽。 我是一名探鬼主播,決...
    沈念sama閱讀 40,145評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼贾惦,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼胸梆!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起纤虽,我...
    開封第一講書人閱讀 39,008評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤乳绕,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后逼纸,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體洋措,經(jīng)...
    沈念sama閱讀 45,443評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,649評(píng)論 3 334
  • 正文 我和宋清朗相戀三年杰刽,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了菠发。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,795評(píng)論 1 347
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡贺嫂,死狀恐怖滓鸠,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情第喳,我是刑警寧澤糜俗,帶...
    沈念sama閱讀 35,501評(píng)論 5 345
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響悠抹,放射性物質(zhì)發(fā)生泄漏珠月。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,119評(píng)論 3 328
  • 文/蒙蒙 一楔敌、第九天 我趴在偏房一處隱蔽的房頂上張望啤挎。 院中可真熱鬧,春花似錦卵凑、人聲如沸庆聘。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,731評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽伙判。三九已至,卻和暖如春值漫,著一層夾襖步出監(jiān)牢的瞬間澳腹,已是汗流浹背织盼。 一陣腳步聲響...
    開封第一講書人閱讀 32,865評(píng)論 1 269
  • 我被黑心中介騙來泰國打工杨何, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人沥邻。 一個(gè)月前我還...
    沈念sama閱讀 47,899評(píng)論 2 370
  • 正文 我出身青樓危虱,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國和親唐全。 傳聞我的和親對(duì)象是個(gè)殘疾皇子埃跷,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,724評(píng)論 2 354