zoukankan      html  css  js  c++  java
  • python爬虫:爬取网站视频

    python爬取百思不得姐网站视频:http://www.budejie.com/video/

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

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    #!/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 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 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')

     

     

    转载:http://blog.51cto.com/xiaogongju/2061754

  • 相关阅读:
    javascript获得浏览器工作区域的大小
    javascript禁止输入数字
    Extjs之遍历Store内的数据
    Extjs之rowEditing编辑状态时列不对齐
    Extjs中numberfield小数位数设置
    【转】vscode常用快捷键整理
    【转】如何提高WEB的性能?
    【转】echarts 使用示例
    uni-app页面配置和跳转
    【转】.NetCore如何将特性和依赖注入有效结合
  • 原文地址:https://www.cnblogs.com/lxwphp/p/10225302.html
Copyright © 2011-2022 走看看