每天学一点之Python100例(27~28)

每天学一点,形成一种知识复利

问题27:获取网页
分析:1.连接远程网页服务器;2.发送HTTP请求这个网页;3.从网页服务器的返回读取HTML代码
demoCode:
#! /usr/bin/python3

import urllib.request
def getHtml(self,url):
page = urllib.request.urlopen(url)
html = page.read()
return html

if __name__=='__main()__':
getHtml("http://www.baidu.com")

问题28:利用re模块爬取网页上的图片
分析:先通过url获取请求,然后通过正则表达式获取图片文件的格式,再通过re模块里的compile()和findall()方法获取图片的url,最后再通过urlretrieve方法获取出图片
demoCode:
#! /usr/bin/python3

import urllib.request
import re

class wormhtml(object):
def __init__(self):
pass

def getHtml(self,url):
page = urllib.request.urlopen(url)
html = page.read()
return html

worm_html = wormhtml()

class wormimage(object):
def __init__(self):
pass

def getimage(self):
html_other = worm_html.getHtml("http://tieba.baidu.com/p/3205263090")
reg = r'src="([.\S]*\.jpg)" pic_ext="jpeg"'

imagereg = re.compile(reg)
imgurls = re.findall(imagereg, str(html_other))

x = 1
for imgurl in imgurls:
urllib.request.urlretrieve(imgurl, '/home/ssq/work/python/samplecode/img/%s.jpg' % x)
x +=1


wormimg = wormimage()

wormimg.getimage()





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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值