python下载文件记录黑名单的实现代码

python下载文件记录黑名单的实现代码,第1张

概述具体代码如下所示:#!/usr/bin/python#-*-coding:GBK-*-#-*-coding:UTF-8-*-fromftplibimportFTPimportos

具体代码如下所示:

#!/usr/bin/python# -*- Coding: GBK -*-# -*- Coding: UTF-8 -*-from ftplib import FTPimport osimport datetimeftp_server = '127.0.0.1' # 对应ftp服务器地址username = 'ponshine' # 用户名password = '1qaz2wsx' # 密码ftp_path = '/GBCC/' # ftp目录local_path = "C:\F\python\pythonwangtest\wyjj2\" #本地的目录# 连接FTPdef ftpconnect():  ftp = FTP()  ftp.set_deBUGlevel(2) # 打开调试级别2,显示详细信息  ftp.connect(ftp_server,21) # 连接  ftp.login(username,password) # 登录,如果匿名登录则用空串代替即可  return ftp# 获取当前的年月日时分秒def getdatetime():  i = datetime.datetime.Now()  date = ("%s%s%s%s%s%s" % (i.year,i.month,i.day,i.hour,i.minute,i.second))  return date # 需返回才能取值# 获取当前的年月日def getdate():  import datetime  i = datetime.datetime.Now()  date = ("%s%s%s" % (i.year,i.day))  return date # 需返回才能取值def downloadfile(remotepath,localpath):  ftp = ftpconnect() # 连接ftp  print ftp.getwelcome() # 显示ftp服务器欢迎信息  ftp_filename = ftp.nlst(remotepath) # 运用nlst()获取文件名  print 'ftp_filename: ',ftp_filename # ftp上的文件名  for eachfile in ftp_filename: # 循坏取文件名    if eachfile.endswith('.AVL'):      localpath_files = eachfile.split("/")      localpath_file = localpath_files[len(localpath_files) - 1] # 文件名:localpath_file= GBCC_201611102155_01.AVL      print "localpath_file--->" + localpath_file      # 创建记录下载文件名的文件名      writefiletext = local_path + getdate() + ".txt" # 记录下载后的文件名      print "writefile_text--->" + writefiletext             if os.path.exists(writefiletext):        print writefiletext + "is exists"      else:        print writefiletext + "is not exists"        makefile = open(writefiletext,"w+")        makefile.close()      files = open(writefiletext,"r") # 打开黑名单表      print "writefiletext--->" + writefiletext      try:        all_the_text = files.read()        print "all_the_text-------》" + all_the_text        if all_the_text.__contains__(localpath_file):          print "文件已下载,不需要重复下载"        else:          print "文件没有下载,现在开始下载"          bufsize = 1024 # 设置缓冲块大小          fp = open(localpath + localpath_file,"wb+")          ftp.retrbinary('RETR ' + eachfile,fp.write,bufsize) # 下载文件          fo = open(writefiletext,"ab+")          fo.write(localpath_file + "\n") # 将每个文件名写入文件          fo.flush() # 刷新文件          fo.close()          fp.flush()      finally:        print "结束了"        files.close()  ftp.set_deBUGlevel(0)  ftp.close()if __name__ == "__main__":  downloadfile("/GBCC","C:\F\python\pythonwangtest\wyjj2\")

  补充:python 黑名单过滤

  需要过滤一些词语

写了下面这个函数,在blackList 文件中添加需要过滤的词语

#过滤黑名单列表中出现的def in_Lists(str):  str_Lists=[]  fd = open('./filter/blackList')  for line in fd.readlines():    str_Lists.append(line.strip())  if str in str_Lists:    return 0  else:    return 1

通过 python 自带的 filter函数 调用, in_Lists,filter函数会过滤掉 bool 值为 1 的列表中的元素

 filter( in_Lists,urls )

总结

以上所述是小编给大家介绍的python下载文件记录黑名单,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对编程小技巧网站的支持!

总结

以上是内存溢出为你收集整理的python下载文件记录黑名单的实现代码全部内容,希望文章能够帮你解决python下载文件记录黑名单的实现代码所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/langs/1201432.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-06-04
下一篇2022-06-04

发表评论

登录后才能评论

评论列表(0条)

    保存