135-1821-9792

python如何递归下载文件夹下所有文件-创新互联

这篇文章主要介绍python如何递归下载文件夹下所有文件,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

创新互联公司-专业网站定制、快速模板网站建设、高性价比印台网站开发、企业建站全套包干低至880元,成熟完善的模板库,直接使用。一站式印台网站制作公司更省心,省钱,快速模板网站建设找我们,业务覆盖印台地区。费用合理售后完善,10年实体公司更值得信赖。

最近想备份网站,但是php下载文件的大小是有大小限制的,而我也懒得装ftp再下载了,就想着暂时弄个二级域名站,然后用python(python3)的requests库直接下载网站根目录下的所有文件以及文件夹。(0-0就是这么任性)

1.安装requests库

pip install requests

2.下载文件夹下所有文件及文件夹

这里需要处理的地方主要是文件夹,这里我们判断出该链接是文件夹时,自动创建文件夹,并递归继续进行操作,否则判断该链接是文件,直接使用requests get方法下载,话不多说,看代码

####春江暮客 www.bobobk.com
import requests
import re
import os
import sys
def help(script):
 text = 'python3 %s https://www.bobobk.com ./' % script

 print(text)
def get_file(url,path):##文件下载函数
  content = requests.get(url)
  print("write %s in %s" % (url,path))
  filew = open(path+url.split("/")[-1],'wb')
  for chunk in content.iter_content(chunk_size=512 * 1024): 
    if chunk: # filter out keep-alive new chunks
      filew.write(chunk)
  filew.close()
def get_dir(url,path): #文件夹处理逻辑
  content = requests.get(url).text
  if "Index of" in content:
    sub_url = re.findall('href="(.*?)" rel="external nofollow" ',content)
  
    print(sub_url)
    for i in sub_url:
      if "/" in i:
      
        i = i.split("/")[0]
        print(i)
        if i!="." and i!="..":
          
          if not os.direxists(path+i):
            os.mkdir(path+i)
         
          get_dir(url+"/"+i,path+i+"/")
          print("url:"+url+"/"+i+"\nurl_path:"+path+i+"/")
      else:
        get_file(url+"/"+i,path)
  else:
    get_file(url,path)
if __name__ == '__main__':
 if not sys.argv[1]:
 help(sys.argv[0])
 exit(0)
 else:
 get_dir(sys.argv[1],"./")</pre><p>至此,就在本地目录完全还原下载原网站的路径和文件了。</p><p>以上是“python如何递归下载文件夹下所有文件”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注创新互联行业资讯频道!</p>            <br>
            本文名称:python如何递归下载文件夹下所有文件-创新互联            <br>
            文章来源:<a href="http://kswsj.com/article/pcghi.html">http://kswsj.com/article/pcghi.html</a>
        </div>
    </div>
    <div class="other">
        <h3>其他资讯</h3>
        <ul>
            <li>
                    <a href="/article/dciidd.html">C#中random.Next方法怎么用-创新互联</a>
                </li><li>
                    <a href="/article/dciiig.html">“十四五”数字泉城建设应用场景-创新互联</a>
                </li><li>
                    <a href="/article/dciijo.html">使用Django框架怎么实现分页显示内容-创新互联</a>
                </li><li>
                    <a href="/article/dciijd.html">CentOS桌面环境中网卡启动失败如何解决-创新互联</a>
                </li><li>
                    <a href="/article/dciisp.html">怎么在python中利用正则提取电话-创新互联</a>
                </li>        </ul>
    </div>
</div>
<!-- end #bd -->
<div class="c"></div>
<!-- begin #fd -->
<div id="fd" class="index-fd pr">
    <div class="map-bg3"></div>
    <div class="wp">
        <div class="fd-top">
            <dl>
                <dt>关于我们</dt>
                <dd>
                    <ul class="ul-fd">
                        <li><a href="http://www.kswsj.com/about#whous">我们是谁</a></li>
                        <li><a href="http://www.kswsj.com/about#ourcus">我们服务的客户</a></li>
                        <li><a href="http://www.kswsj.com/about#ourteam">我们的团队</a></li>
                    </ul>
                </dd>
            </dl>
            <dl>
                <dt>我们的服务</dt>
                <dd>
                    <ul class="ul-fd">
                        <li><a href="http://www.kswsj.com/service#webbuit">网站建设</a></li>
                        <li><a href="http://www.kswsj.com/service#weiweb">H5响应式 交互网站</a></li>
                        <li><a href="http://www.kswsj.com/service#webmobel">移动端 & 微网站定制</a></li>
                        <li><a href="http://www.kswsj.com/service#servweb">服务流程</a></li>
                        <li><a href="http://www.kswsj.com/service#solution">行业解决方案</a></li>
                    </ul>
                </dd>
            </dl>
            <dl>
                <dt>网站建设案例</dt>
                <dd>
                    <ul class="ul-fd">

                        <li><a href="http://www.kswsj.com/case/">公司集团</a></li>

                        <li><a href="http://www.kswsj.com/case/">数码电子科技</a></li>

                        <li><a href="http://www.kswsj.com/case/">建筑与设计</a></li>

                        <li><a href="http://www.kswsj.com/case/">安防门禁</a></li>

                        <li><a href="http://www.kswsj.com/case/">管理咨询美容</a></li>

                        <li><a href="http://www.kswsj.com/case/">外贸行业</a></li>

                    </ul>
                </dd>
            </dl>
            <dl>
                <dt>新闻动态</dt>
                <dd>
                    <ul class="ul-fd">

                        <li><a href="/news/2.html">成都网站建设</a></li><li><a href="/news/3.html">成都网站制作</a></li><li><a href="/news/4.html">成都网站设计</a></li>
                    </ul>
                </dd>
            </dl>
            <dl>
                <dt>联系我们</dt>
                <dd class="pr">
                    <p><a href="http://www.kswsj.com/news/" class="weixin"></a><a href="http://www.kswsj.com/news/" class="sina"></a><span class="weixin-pic"><img src="/Public/Home/pic/ewm.jpg"></span></p>
                    <p><b class="tel">135-1821-9792</b></p>
                    <h5>公司服务热线</h5>
                </dd>
            </dl>
        </div>
        <div class="link">
            友情链接:
            <a href="http://www.cdxwcx.cn/bj/" title="网站制作价格" target="_blank">网站制作价格</a>   <a href="http://www.jnanhua.com/" title="led显示屏" target="_blank">led显示屏</a>   <a href="http://www.zyfdjwx.com/" title="zyfdjwx.com" target="_blank">zyfdjwx.com</a>   <a href="http://www.fjdkgd.com/" title="fjdkgd.com" target="_blank">fjdkgd.com</a>   <a href="http://www.ynruijie.cn/" title="成都个体注册" target="_blank">成都个体注册</a>   <a href="http://www.wzjierui.cn/" title="温江网站建设" target="_blank">温江网站建设</a>   <a href="http://m.xwcx.net/phone/" title="手机网站版本" target="_blank">手机网站版本</a>   <a href="http://www.kjdeyu.com/" title="营山月子会所" target="_blank">营山月子会所</a>   <a href="http://www.ruijiemsc.com/" title="瑞杰企业管理" target="_blank">瑞杰企业管理</a>   <a href="http://www.cdxwcx.cn/tuoguan/mianyang.html" title="四川绵阳主机托管" target="_blank">四川绵阳主机托管</a>           </div>
    </div>
    <div class="fd-copy">
        <div class="wp">
            <p><span style="color:#CCCCCC;">Copyright © 2009-2022 www.kswsj.com 成都快上网科技有限公司 版权所有</span> <a href="http://beian.miit.gov.cn/" target="_blank" rel="nofollow" style="color:#CCCCCC;">蜀ICP备19037934号</a></p>
        </div>
    </div>
</div>
<div class="side">
    <ul>
        <li><a href="http://wpa.qq.com/msgrd?v=3&uin=631063699&site=qq&menu=yes" target="_blank">
            <div class="sidebox"><img src="/Public/Home/pic/side_icon02.png">在线咨询</div>
        </a></li>
        <li><a href="http://wpa.qq.com/msgrd?v=3&uin=631063699&site=qq&menu=yes" target="_blank">
            <div class="sidebox"><img src="/Public/Home/pic/side_icon01.png">在线咨询</div>
        </a></li>
        <li><a href="tel:135-1821-9792">
            <div class="sidebox"><img src="/Public/Home/pic/side_icon03.png"><span style="font-size:14px">135-1821-9792</span></div>
        </a></li>
    </ul>
</div>
<div class="side2">
    <ul>
        <li><a href="http://www.kswsj.com/news/"><img src="/Public/Home/pic/r_icon1.png" alt="成都网站建设"></a>
            <div class="weixin"><em></em><img src="/Public/Home/pic/ewm.jpg" alt="成都网站建设"></div>
        </li>
        <li><a href="javascript:goTop();" class="sidetop"><img src="/Public/Home/pic/r_icon2.png"></a></li>
    </ul>
</div>
<div class="fot">
    <ul>
        <li>
            <a href="https://p.qiao.baidu.com/cps/mobileChat?siteId=11284691&userId=6256368&type=1&reqParam=%20{%22from%22:0,%22sessionid%22:%22%22,%22siteId%22:%2211284691%22,%22tid%22:%22-1%22,%22userId%22:%226256368%22,%22ttype%22:1,%22siteConfig%22:%20{%22eid%22:%226256368%22,%22queuing%22:%22%22,%22siteToken%22:%226ce441ff9e2d6bedbdfc2a4138de449e%22,%22userId%22:%226256368%22,%22isGray%22:%22false%22,%22wsUrl%22:%22wss://p.qiao.baidu.com/cps3/websocket%22,%22likeVersion%22:%22generic%22,%22siteId%22:%2211284691%22,%22online%22:%22true%22,%22webRoot%22:%22//p.qiao.baidu.com/cps3/%22,%22bid%22:%22160142915792139572%22,%22isSmallFlow%22:0,%22isPreonline%22:0,%22invited%22:0%20},%22config%22:%20{%22themeColor%22:%224d74fa%22%20}%20}&appId=&referer=&iswechat=0&expectWaiter=-1&openid=null&otherParam=null&telephone=null&speedLogId=null&eid=null&siteToken=6ce441ff9e2d6bedbdfc2a4138de449e" target="_blank">
                <img src="/Public/Home/pic/fot1.png" alt="">
                <p>在线咨询</p>
            </a>
        </li>
        <li>
            <a href="tel:18980820575" target="_blank">
                <img src="/Public/Home/pic/fot2.png" alt="">
                <p>拨打电话</p>
            </a>
        </li>
    </ul>
</div>
<script type="text/javascript" src="/Public/Home/pic/jquery.js"></script>
<script type="text/javascript" src="/Public/Home/pic/lib.js"></script>
</body></html>
<script>
    $(".con img").each(function(){
        var src = $(this).attr("src");    //获取图片地址
        var str=new RegExp("http");
        var result=str.test(src);
        if(result==false){
            var url = "https://www.cdcxhl.com"+src;    //绝对路径
            $(this).attr("src",url);
        }
    });
    window.onload=function(){
        document.oncontextmenu=function(){
            return false;
        }
    }
</script>