为了账号安全,请及时绑定邮箱和手机立即绑定

第一次爬虫实例

标签:
深度学习

第一次爬虫实例

1、这是我第一次写的爬虫实例,写的不好请见谅,最后发现爬取的次数多了,被网站拉黑了,还是需要代理才行,代理还不太清楚怎么弄就先这样了

后面请大神可以帮忙改下怎么使用代理爬取。

第一次爬取网站的所有电影信息(仅供参考)

具体思路就是先获取第一页上的信息

然后根据翻页上的页数来确定爬取多少页

下面是具体代码:

复制代码

import requestsfrom bs4 import BeautifulSoupfrom concurrent.futures import ThreadPoolExecutor


root = 'http://www.btrenren.com'def  bt_video(num):
    url = "http://www.btrenren.com/index.php/Index/index/p/%s.html"%num
    head = {"User-Agent":"Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/57.0.2987.98 Safari/537.36 LBBROWSER"}

    html = requests.get(url=url,headers=head)
    soup = BeautifulSoup(html.content,'lxml')
    data = soup.find('div',class_="ml")
    data = data.find_all(class_="title")
    with open("video.txt", 'a', encoding='utf-8') as f:        for i in data:            #电影名
            name = i.find_all('font')[1].get_text().split('/')[0].strp()            #日期国家
            vlue = i.find_all(class_='des')[0].get_text().split('\n')[0].strp()            #演员
            vlue1 = i.find_all(class_='des')[0].get_text().split('\n')[1].strp()            #豆瓣评分
            douban = i.find(class_="rt").get_text().strp()            #网页路径
            href = root + i.find_all('a')[1].get('href').strp()            #print(name,vlue,vlue1,douban,href)
            f.write('%s,%s,%s,%s,%s\n' % (name, vlue, vlue1, douban,href))    print(num)def num_video():
    url = "http://www.btrenren.com/index.php/Index/index/p/1.html"
    head = {"User-Agent": "Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/57.0.2987.98 Safari/537.36 LBBROWSER"}
    html = requests.get(url=url, headers=head)
    soup = BeautifulSoup(html.content, 'lxml')
    number = soup.find('ul',class_="pagelist")
    number = number.find_all('span',class_="rows")
    num = number[0].get_text().split(' ')[1]    return numif __name__ == "__main__":
    executor = ThreadPoolExecutor(max_workers=30)
    num = int(num_video())    for i in range(1,num):
        executor.submit(bt_video,i)
    executor.shutdown()
    exit()

复制代码

原文出处:https://www.cnblogs.com/xu743876685/p/9575254.html

点击查看更多内容
1人点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消