简洁的python,简洁的urllib,保存图片

本文介绍了一种使用Python的urllib模块从Bing网站抓取每日更换的背景图片的方法。通过解析网页源代码找到图片链接,并利用urllib提供的函数完成图片的下载。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

  1. 实现图片下载  
  2. import urllib  
  3. url = r"http://www.javaeye.com/images/logo.gif"  
  4. path = r"h:/downloads/1.jpg"  
  5. data = urllib.urlopen(url).read()  
  6. f = file(path,"wb")  
  7. f.write(data)  
  8. f.close() 

 

     虽然我对微软的搜索引擎bing没有太多的使用,但是感觉它的背景图片还是不错,而且每天都在更换,有一次看到一张不错的图片,想下载下来,右键点击竟然下载不下来,没有右键另存为图片的选项,于是网上找到了一个软件能够下载bing背景图片。这几天看Python的web编程urllib模块,下意识的打开bing的网页源代码,搜索了下jpg关键字,尽然找到了g_img={url:'//fd//hpk2//BambooBoat_ZH-CN1057817945.jpg'的字符串,用那个软件下的图片名字恰好是BambooBoat_ZH-CN1057817945.jpg,于是猜想前面便是图片在www.bing.com服务器上存放的地址,里面的/字符可能就是转义符号,便得到地址www.bing.com/fd/hpk2/BambooBoat_ZH-CN1057817945.jpg,打开一看,果然就是背景图片,便写下了这段脚本

 

 

import urllib
import time
def main():
    url = 'http://www.bing.com'
    f = urllib.urlopen(url)
    html = f.read()
    f.close()
    a = html[html.index('//fd//hpk2'):]
    data = a[:a.index('/',id:')]
    url = data.replace('//', '')
    url = 'http://www.bing.com'+url
    name=time.strftime("%Y%m%d", time.localtime())
    name=name+".jpg"  #path = "d:/python1" +'//'+name
    urllib.urlretrieve(url,name)   #s=urllib.urlretrieve(url,path)

if __name__ == "__main__":
    main()

 

urllib的urlretrieve

参数4个 urllib.urlretrieve = urlretrieve(url, filename=None, reporthook=None, data=None)

url: 你要下载的网址

filename :你要保存的文件

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值