争怎路由网/网站教程/内容

使用Python脚本如何完成递归拷贝文件

网站教程2024-06-11 阅读
网站建设是指使用标识语言(markup language),通过一系列设计、建模、和执行的过程将电子格式的信息通过互联网传输,最终以图形用户界面(GUI)的形式被用户所浏览。简单来说,网页设计的目的就是产生网站。简单的信息如文字,图片(GIF,JPEG,PNG)和表格,都可以通过使超文件标示语言、可扩展超文本标记语言等标示语言放置到网站页面上。
使用Python脚本如何实现递归拷贝文件

  这是待拷贝的文件夹根目录,每个子目录下都有若干照片。

 

使用Python脚本如何实现递归拷贝文件

 

  废话少说,上代码:

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

  #!/usr/bin/python

  #Filename:copyfile.py

  import os,shutil

  def mycopy(srcpath,dstpath):

  if not os.path.exists(srcpath):

  print "srcpath not exist!"

  if not os.path.exists(dstpath):

  print "dstpath not exist!"

  for root,dirs,files in os.walk(srcpath,True):

  for eachfile in files:

  shutil.copy(os.path.join(root,eachfile),dstpath)

  srcpath='e:\\pic'

  dstpath='f:\\pictotal'

  mycopy(srcpath,dstpath)

  运行这个脚本,去f盘看看:

使用Python脚本如何实现递归拷贝文件

  照片都拷贝了过来,果然有很多照片(底下还有很多,没截完)

  代码没有什么难懂的,主要是os.walk()函数,这个函数返回指定路径的三元组(起始路径,起始路径下的目录,起始路径下不带路径名的文件名列表)

  它直接可以递归遍历到指定目录下的所有目录及文件名,比较好用。

  可以看出,python仅需短短几行的代码就完成了这个工作,还是很方便的。若用C++来实现代码就比这个长了。

  也可以用os.listdir(dirname):函数来实现,listdir函数列出dirname下的目录和文件,然后通过一个判断:若是文件,则拷贝;若是目录,则继续递归

  遍历,显然没有walk()函数用起来方便。不过不知道walk()函数内部是怎么实现的,若是直接将根目录下的所有文件存在list中性能上可能不太好,后面可以用listdir()对比测一下。

  大家应该知道要选哪个方法了嘛~挺简单的~但是挺实用~

 

推荐阅读:

Python正则表达式的使用教程

大多数人在上网的时候,都会浏览网页提供给我们的信息。

……

相关阅读