日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

Python爬蟲(chóng)獲取豆瓣電影并寫入excel

瀏覽:213日期:2022-07-15 17:07:55

豆瓣電影排行榜前250 分為10頁(yè),第一頁(yè)的url為https://movie.douban.com/top250,但實(shí)際上應(yīng)該是https://movie.douban.com/top250?start=0 后面的參數(shù)0表示從第幾個(gè)開(kāi)始,如0表示從第一(肖申克的救贖)到第二十五(觸不可及),https://movie.douban.com/top250?start=25表示從第二十六(蝙蝠俠:黑暗騎士)到第五十名(死亡詩(shī)社)。等等,

所以可以用一個(gè)步長(zhǎng)為25的range的for循環(huán)參數(shù)

復(fù)制代碼 代碼如下:for i in range(0, 250, 25): print(i)

分析完頁(yè)面組成后,開(kāi)始獲取頁(yè)面,直接request.get()發(fā)現(xiàn)沒(méi)有返回任何東西,輸出一下響應(yīng)碼

url = ’https://movie.douban.com/top250?start=0’res = request.get(url=url)print(res.status_code)

發(fā)現(xiàn)返回響應(yīng)碼418

以前沒(méi)見(jiàn)過(guò)這個(gè),拉網(wǎng)線上網(wǎng)查一下,發(fā)現(xiàn)給get里面加一個(gè)header參數(shù)就行了

這里可以用自己瀏覽器的user-agent,如

headers = {’User-Agent’: ’Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/73.0.3683.103 Safari/537.36’}

或者用fake_agent(安裝直接用pip install fake_agent) 來(lái)為自己生成一個(gè)隨機(jī)的agent添加到header字典中

from fake_useragent import UserAgentheaders = {’User-Agent’: UserAgent().random}

之后就可以得到頁(yè)面源碼了。

然后使用lxml.etree,即xpath解析頁(yè)面源碼。用瀏覽器插件xpath finder快速定位到元素

Python爬蟲(chóng)獲取豆瓣電影并寫入excel

import requestsimport lxml.etree as etreeurl = ’https://movie.douban.com/top250?start=0’headers = {’User-Agent’: ’Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/73.0.3683.103 Safari/537.36’}res = requests.get(url=url, headers=headers)print(res.text)html = etree.HTML(res.text)name = html.xpath('/html/body/div[3]/div[1]/div/div[1]/ol/li[1]/div/div[2]/div[1]/a/span[1]')print(name)

但是直接這樣子,解析到的是這樣的結(jié)果

[<Element span at 0x20b2f0cc488>]

Python爬蟲(chóng)獲取豆瓣電影并寫入excel

關(guān)于這東西是什么,有文章寫的很好:https://www.jb51.net/article/132145.htm

這里我直接寫解決部分,在使用xpath解析時(shí),后面加上/text()

name = html.xpath('/html/body/div[3]/div[1]/div/div[1]/ol/li[1]/div/div[2]/div[1]/a/span[1]/text()')

解決后,再使用xpath finder插件,一步一步獲取到電影所有數(shù)據(jù)

最后把這個(gè)寫在函數(shù)里,外面再套上一開(kāi)始說(shuō)的循環(huán),就OK了

# -*- coding: utf-8 -*-import requestsimport lxml.etree as etreedef get_source(page): url = ’https://movie.douban.com/top250?start={}’.format(page) headers = { ’User-Agent’: ’Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/73.0.3683.103 Safari/537.36’} print(url) res = requests.get(url=url, headers=headers) print(res.status_code) html = etree.HTML(res.text) for i in range(1, 26): name = html.xpath('/html/body/div[3]/div[1]/div/div[1]/ol/li[{}]/div/div[2]/div[1]/a/span[1]/text()'.format(i)) info = html.xpath('/html/body/div[3]/div[1]/div/div[1]/ol/li[{}]/div/div[2]/div[2]/p[1]/text()'.format(i)) score = html.xpath( '/html/body/div[3]/div[1]/div/div[1]/ol/li[{}]/div/div[2]/div[2]/div/span[2]/text()'.format(i)) slogan = html.xpath( '/html/body/div[3]/div[1]/div/div[1]/ol/li[{}]/div/div[2]/div[2]/p[2]/span/text()'.format(i)) print(name[0]) print(info[0].replace(’ ’, ’’)) print(info[1].replace(’ ’, ’’)) print(score[0]) print(slogan[0])n = 1for i in range(0, 250, 25): print(’第%d頁(yè)’ % n) n += 1 get_source(i) print(’==========================================’)

在定位時(shí),發(fā)現(xiàn)有4部電影介紹沒(méi)有slogan,導(dǎo)致獲取到的信息為空列表,也就導(dǎo)致了list.append()會(huì)出錯(cuò)。所以我加上了幾個(gè)差錯(cuò)處理,解決方式可能有點(diǎn)傻,如果有更好的解決辦法,洗耳恭聽(tīng)

代碼在最后可以看到

Python爬蟲(chóng)獲取豆瓣電影并寫入excel

EXCEL保存部分

這里我用的xlwt

book = xlwt.Workbook()

sheet = book.add_sheet(u’sheetname’, cell_overwrite_ok=True)

創(chuàng)建一個(gè)sheet表單。

數(shù)據(jù)保存到一個(gè)大列表中,列表嵌套列表

再通過(guò)循環(huán)把數(shù)據(jù)導(dǎo)入到excel表單中

r = 1 for i in LIST: #有10頁(yè) for j in i: #有25條數(shù)據(jù) c = 2 for x in j: #有5組數(shù)據(jù)print(x)sheet.write(r, c, x)c += 1 r += 1

最后在保存一下

book.save(r’douban.xls’)

注意文件后綴要用xls,用xlsx會(huì)導(dǎo)致文件打不開(kāi)

然后就大功告成了

打開(kāi)文件,手動(dòng)加入排名,等部分信息(這些也可以在程序里完成,我嫌麻煩,就沒(méi)寫,直接手動(dòng)來(lái)的快)

Python爬蟲(chóng)獲取豆瓣電影并寫入excel

前面的✓是我自己整的,用于記錄那些看過(guò),那些沒(méi)看過(guò)

這也是我寫這個(gè)東西的最初的目的

完整代碼在下面,僅用于參考

# -*- coding: utf-8 -*-import requestsimport lxml.etree as etreeimport xlwtdef get_source(page): List = [] url = ’https://movie.douban.com/top250?start={}’.format(page) headers = { ’User-Agent’: ’Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/73.0.3683.103 Safari/537.36’} print(url) res = requests.get(url=url, headers=headers) print(res.status_code) html = etree.HTML(res.text) for i in range(1, 26): list = [] name = html.xpath('/html/body/div[3]/div[1]/div/div[1]/ol/li[{}]/div/div[2]/div[1]/a/span[1]/text()'.format(i)) info = html.xpath('/html/body/div[3]/div[1]/div/div[1]/ol/li[{}]/div/div[2]/div[2]/p[1]/text()'.format(i)) score = html.xpath( '/html/body/div[3]/div[1]/div/div[1]/ol/li[{}]/div/div[2]/div[2]/div/span[2]/text()'.format(i)) slogan = html.xpath( '/html/body/div[3]/div[1]/div/div[1]/ol/li[{}]/div/div[2]/div[2]/p[2]/span/text()'.format(i)) try: list.append(name[0]) except: list.append(’----’) try: list.append(info[0].replace(’ ’, ’’).replace(’n’, ’’)) except: list.append(’----’) try: list.append(info[1].replace(’ ’, ’’).replace(’n’, ’’)) except: list.append(’----’) try: list.append(score[0]) except: list.append(’----’) try: list.append(slogan[0]) except: list.append(’----’) List.append(list) return Listn = 1LIST = []for i in range(0, 250, 25): print(’第{}頁(yè)’.format(n)) n += 1 List = get_source(i) LIST.append(List)def excel_write(LIST): book = xlwt.Workbook() sheet = book.add_sheet(u’sheetname’, cell_overwrite_ok=True) r = 1 for i in LIST: #有10頁(yè) for j in i: #有25條數(shù)據(jù) c = 2 for x in j: #有5組數(shù)據(jù)print(x)sheet.write(r, c, x)c += 1 r += 1 book.save(r’douban1.xls’) #保存代碼excel_write(LIST)

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: 豆瓣 Python
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
免费在线成人| 亚洲在线一区| 中文字幕成人| 丁香六月综合| 成人国产精品一区二区免费麻豆| 伊人久久一区| 亚洲影院天堂中文av色| 久久国产亚洲| 午夜精品成人av| 欧洲一区二区三区精品| 成人三级高清视频在线看| 久久久免费人体| 久久99国产精品视频| 久久伊人国产| yellow在线观看网址| 伊人久久国产| 国产主播一区| 岛国av在线网站| 黄色精品视频| 亚洲免费成人av在线| 欧美一区自拍| 久久av影院| 国产欧美精品| 亚洲精品成人图区| 极品裸体白嫩激情啪啪国产精品| 亚洲国产不卡| 亚洲欧美激情诱惑| 日韩欧美中文字幕一区二区三区 | 亚洲成a人片| 久久影视一区| 亚洲一区有码| 国产精品视频3p| 欧美激情国产在线| 久久婷婷一区| 亚洲一区免费| 日韩精品一区二区三区免费视频| 国产一级成人av| 久久女人天堂| 欧美特黄一级大片| 在线精品亚洲| 日韩精品午夜| 老牛影视一区二区三区| 日产欧产美韩系列久久99| 国产一卡不卡| 美女视频免费精品| 午夜精品亚洲| 红桃视频欧美| 91九色综合| 久久精品女人| 欧美精选一区二区三区| 一区二区高清| 久久免费视频66| 黄色精品网站| 国产精品久久久久久久久久白浆| 成年男女免费视频网站不卡| 亚洲深爱激情| 老司机免费视频一区二区三区| 伊人久久大香线蕉av不卡| 亚洲精品影视| 高清一区二区三区av| 久久av在线| 六月丁香综合在线视频| 99亚洲视频| 精品视频在线观看网站| 激情自拍一区| 欧美激情视频一区二区三区在线播放| 日韩在线短视频| 日韩福利视频网| 一区二区小说| 麻豆精品新av中文字幕| 男女精品网站| 日韩欧美看国产| 国产精品中文字幕亚洲欧美| 99在线观看免费视频精品观看| 精品国产一区二区三区性色av| 男女男精品视频网| 五月激情久久| 久久99精品久久久野外观看| 久久午夜精品一区二区| 精品欧美视频| 日韩欧乱色一区二区三区在线| 激情自拍一区| 国产精品久久观看| 欧美一区影院| 蜜臀av一区二区三区| 亚洲一区资源| 国产三级一区| 久久国产精品久久w女人spa| 国产美女高潮在线| 欧美日韩18| 日韩中文字幕91| 欧美jjzz| 视频二区不卡| 国产精品久久久久蜜臀 | 日韩影院免费视频| 成人美女视频| 国产精品1luya在线播放| 三级一区在线视频先锋| 国产精品av一区二区| 免费在线亚洲| 欧美一级久久| 日韩有吗在线观看| 欧美专区在线| 国产视频一区三区| 美女网站一区| 亚洲成人不卡| 国产精品伦理久久久久久| 欧美日韩一区二区高清| 视频一区二区中文字幕| 九一精品国产| 欧美sss在线视频| 中文在线а√天堂| 国产一区二区三区探花| 国产精品亚洲欧美一级在线| 亚洲乱码一区| 午夜欧美精品| 久久人人97超碰国产公开结果| 国产精品伦理久久久久久| 麻豆一区二区三| 国产精品久久久网站| 国产精品亲子伦av一区二区三区| 日韩精品成人| 日本不卡高清| 欧美精品中文| 国产亚洲欧美日韩精品一区二区三区| 无码日韩精品一区二区免费| 蜜桃av一区二区| 在线日韩成人| 男人的天堂久久精品| 热久久久久久久| 亚洲精品影视| 欧美久久精品| 毛片不卡一区二区| 国内在线观看一区二区三区| 国产免费久久| 精品国内亚洲2022精品成人| 美女国产精品久久久| 国产不卡av一区二区| 伊伊综合在线| 亚洲午夜电影| 在线亚洲观看| 蜜桃视频一区二区三区| 亚洲1区在线| 91欧美日韩在线| 国产精品1区| 精品视频自拍| 午夜欧美巨大性欧美巨大| 亚洲成人精品| 欧美日韩国产探花| 蜜臀av在线播放一区二区三区| 久久香蕉精品| 日韩av电影一区| 精品国产不卡| 久久国产影院| 亚洲人成高清| 国产精品成人一区二区网站软件| 精品国产三区在线| 久久美女精品| 色综合视频一区二区三区日韩| 欧美激情网址| 亚洲福利一区| 综合一区av| 久久精品伊人| 欧美一区二区三区高清视频| 水蜜桃久久夜色精品一区的特点 | 国产精品主播| 成人一区而且| 欧美日韩国产高清| 日韩超碰人人爽人人做人人添| 毛片不卡一区二区| 欧美 日韩 国产一区二区在线视频| 蜜桃久久精品一区二区| 国产精品久久久久毛片大屁完整版| 日韩欧美三级| 日韩中文字幕1| 精品视频网站| 夜夜嗨av一区二区三区网站四季av| 91成人精品在线| 国产资源在线观看入口av| 国产99亚洲| 97精品久久| 四虎4545www国产精品| 蜜臀av性久久久久蜜臀aⅴ流畅 | 免费久久精品视频| 国产视频一区二| 91精品国产乱码久久久久久久| 免费成人性网站| 久久免费精品| 国产国产精品| 国产精品一线天粉嫩av| 色婷婷狠狠五月综合天色拍| 综合激情网站| 欧美韩日一区| 日韩成人一级| 激情五月综合| 精品国产乱码久久久久久樱花| 美女精品在线观看| av高清不卡| 91p九色成人| 国产视频一区三区|