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 文件夹,执行后结果如下:

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

注意报错:

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

最新文章

  1. sql笨办法同步数据
  2. 学习Maven之Properties Maven Plugin
  3. 使用 Sublime Text 2 开发 Unity3D 项目
  4. Calendar日历小程序
  5. __attribute__特性介绍以及变量和函数特定布局设置
  6. HTML-点击收藏功能模块
  7. ZOJ 3188 ZOJ 3188 Treeland Exhibition(树形DP)
  8. 参数修饰符ref,out ,params的区别
  9. PHP初入--表单元素
  10. USB安装centos6系统(centos7需要换软件)
  11. 52. N-Queens II N皇后II
  12. makefile 常用函数
  13. PHP中工厂模式与策略模式区别
  14. android 开发 实现一个ListView套嵌GirdView的滚动布局
  15. findHomography和perspectiveTransform
  16. windows server 2003R2\2008R2\2012\2016 安装【故障转移群集】cluster
  17. docker 网络实践
  18. 69. Sqrt(x)(二分查找)
  19. (C#) 多线程访问int, bool 等值类型变量
  20. Ajax的跨域请求——JSONP的使用

热门文章

  1. C# 调用腾讯云接口获取视频基本信息
  2. 20145234黄斐《Java程序设计》第七周学习总结(课本部分)
  3. 20145234黄斐《Java程序设计》第五周学习总结
  4. BZOJ2761_不重复数字_KEY
  5. 西安Uber优步司机奖励政策(12月28日到1月3日)
  6. Myeclipse - 问题集 - specified vm install not found
  7. Kubernetes 在网易云中的落地优化实践
  8. 会声会影X10x9x8最新教程
  9. 「Python」conda与pip升级所有的包
  10. 谁说接口不能有代码?—— Kotlin接口简介(KAD 26)