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

python爬虫:爬取网站视频

标签:
Python


新建一个py文件,代码如下:

#!/usr/bin/python

# -*- coding: UTF-8 -*-

 

import urllib,re,requests

import sys

reload(sys)

sys.setdefaultencoding('utf-8')

 

url_name = [] #url name

 

def get():

    #获取源码

    hd = {"User-Agent":"Mozilla/5.0 (Windows NT 6.3; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.110 Safari/537.36"}

    url = 'http://www.budejie.com/video/'

    html = requests.get(url,headers=hd).text

    url_content = re.compile(r'(<div class="j-r-list-c">.*?</div>.*?</div>)',re.S) #编译

    url_contents = re.findall(url_content,html) #匹配

 

    for i in url_contents:

        #匹配视频

        url_reg = r'data-mp4="(.*?)"'  #视频地址

        url_items = re.findall(url_reg,i)

        #print url_items

        if url_items:  #判断视频是否存在

            name_reg = re.compile(r'<a href="/detail-.{8}?.html">(.*?)</a>',re.S)

            name_items = re.findall(name_reg,i)

            #print name_items[0]

            for i,k in zip(name_items,url_items):

                url_name.append([i,k])

                print i,k

    for i in url_name:  #i[1]=url i[0]=name

        urllib.urlretrieve(i[1],'video\\%s.mp4' % (i[0].decode('utf-8')))

 

if __name__ == "__main__":

    get()



在 py 文件下新建一个 video 文件夹,执行后结果如下:

wKiom1kkMz-i8-RdAAIVKL2KXsw022.png


在 video 文件夹可以看到下载好的视频

wKioL1kkM1KQyw43AAQpNrfCuQc669.png

注意报错:

UnicodeEncodeError: 'ascii' codec can't encode characters in position 0-9: ordinal not in range(128)

解决:

import sys
reload(sys)

sys.setdefaultencoding('utf-8')



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

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

评论

作者其他优质文章

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

100积分直接送

付费专栏免费学

大额优惠券免费领

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

举报

0/150
提交
取消