python实现下载指定网址所有图片的方法
admin
2023-07-31 02:36:07
0

本文实例讲述了python实现下载指定网址所有图片的方法。分享给大家供大家参考。具体实现方法如下:

#coding=utf-8
#download pictures of the url
#useage: python downpicture.py www.baidu.com
import os
import sys
from html.parser import HTMLParser
from urllib.request import urlopen
from urllib.parse import urlparse
def getpicname(path):
  \'\'\'  retrive filename of url    \'\'\'
  if os.path.splitext(path)[1] == \'\':
    return None
  pr=urlparse(path)
  path=\'http://\'+pr[1]+pr[2]
  return os.path.split(path)[1]
def saveimgto(path, urls):
  \'\'\'
  save img of url to local path
  \'\'\'
  if not os.path.isdir(path):
    print(\'path is invalid\')
    sys.exit()
  else:
    for url in urls:
      of=open(os.path.join(path, getpicname(url)), \'w+b\')
      q=urlopen(url)
      of.write(q.read())
      q.close()
      of.close()
class myhtmlparser(HTMLParser):
  \'\'\'put all src of img into urls\'\'\'
  def __init__(self):
    HTMLParser.__init__(self)
    self.urls=list()
    self.num=0
  def handle_starttag(self, tag, attr):
    if tag.lower() == \'img\':
      srcs=[u[1] for u in attr if u[0].lower() == \'src\']
      self.urls.extend(srcs)
      self.num = self.num+1
if __name__ == \'__main__\':
  url=sys.argv[1]
  if not url.startswith(\'http://\'):
    url=\'http://\' + sys.argv[1]
  parseresult=urlparse(url)
  domain=\'http://\' + parseresult[1]
  q=urlopen(url)
  content=q.read().decode(\'utf-8\', \'ignore\')
  q.close()
  myparser=myhtmlparser()
  myparser.feed(content)
  for u in myparser.urls:
    if (u.startswith(\'//\')):
      myparser.urls[myparser.urls.index(u)]= \'http:\'+u
    elif u.startswith(\'/\'):
      myparser.urls[myparser.urls.index(u)]= domain+u
  saveimgto(r\'D:\\python\\song\', myparser.urls)
  print(\'num of download pictures is {}\'.format(myparser.num))

运行结果如下:

num of download pictures is 19

希望本文所述对大家的Python程序设计有所帮助。

相关内容

热门资讯

Mobi、epub格式电子书如... 在wps里全局设置里有一个文件关联,打开,勾选电子书文件选项就可以了。
500 行 Python 代码... 语法分析器描述了一个句子的语法结构,用来帮助其他的应用进行推理。自然语言引入了很多意外的歧义,以我们...
定时清理删除C:\Progra... C:\Program Files (x86)下面很多scoped_dir开头的文件夹 写个批处理 定...
scoped_dir32_70... 一台虚拟机C盘总是莫名奇妙的空间用完,导致很多软件没法再运行。经过仔细检查发现是C:\Program...
65536是2的几次方 计算2... 65536是2的16次方:65536=2⁶ 65536是256的2次方:65536=256 6553...
小程序支付时提示:appid和... [Q]小程序支付时提示:appid和mch_id不匹配 [A]小程序和微信支付没有进行关联,访问“小...
pycparser 是一个用... `pycparser` 是一个用 Python 编写的 C 语言解析器。它可以用来解析 C 代码并构...
微信小程序使用slider实现... 众所周知哈,微信小程序里面的音频播放是没有进度条的,但最近有个项目呢,客户要求音频要有进度条控制,所...
Apache Doris 2.... 亲爱的社区小伙伴们,我们很高兴地向大家宣布,Apache Doris 2.0.0 版本已于...
python清除字符串里非数字... 本文实例讲述了python清除字符串里非数字字符的方法。分享给大家供大家参考。具体如下: impor...