看漫画学python下载_Python下载漫画

上午起来提不起劲,于是就用电脑看漫画,但是在线看漫画好烦,就想下下来看。一个一个点太麻烦,于是花了点时间用python写了个demo,把爱漫画的漫画下载下来,这样就可以随时随地看了。这也是我首次尝试用python写不是数据处理的东西,还是很开心的。

做的具体思路就是利用python提供的urllib,urllib2的内容来做的,其中辅助了正则表达式模块re,用来进行匹配。因为自己水平不咋地,代码有点乱。。

代码:

#!/usr/bin/env python

#-*- coding: utf-8 -*-

import urllib as ub1

import urllib2 as ub2

import re

def downloadCartoon(bookurl,localdir):

req = ub2.Request(bookurl)

f = ub2.urlopen(req)

for eachline in f:

line = eachline.strip()

if re.match('.*下载.*',line):

wordList = line.split('\"')

downloadurl='http://www.bbhou.com/'+wordList[1]

req1 = ub2.Request(downloadurl)#第2个是下载链接的页面URL地址,构造这个request,然后再次请求一个网页

#跳转到下载的页面,再次请求并进行下载

f1 = ub2.urlopen(req1)

for item in f1:

item2 = item.strip()

if re.match('.*zip',item2):

wl = item2.split('\"')

localname = localdir+wl[3]+'.zip'

ub1.urlretrieve(wl[1],localname.decode('utf-8'))#利用下载链接,下载到本地

print localname.decode('utf-8')+' downloaded.'

def GetCartoon(url):

#这里是漫画所有的列表,区域,这里循环获得每一卷的地址,然后调用上一个函数去进行下载

rooturl = 'http://www.bbhou.com/' #这是漫画地址的根目录,后面的连接需要根据这个进行跳转

request = ub2.Request(url)

response = ub2.urlopen(request)

lsturl = []

for every in response:

line = every.strip()

if re.match('.*/manhua/.*html.*',line):

piclist = line.split('\"')

for item in piclist:

if re.match('.*html.*',item):

cururl = rooturl+item

lsturl.append(cururl)

for url in lsturl:

try:

downloadCartoon(url,'E:\\')

except Exception,e:

continue

GetCartoon('http://www.bbhou.com/manhua/jinjidejuren/')

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值