人生苦短,我用Python(一)—Python实现指定文件夹中同类文档的收集工作

本文主要是介绍人生苦短,我用Python(一)—Python实现指定文件夹中同类文档的收集工作,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

写在前面:博主本职工作为网络工程师,对于编程没有系统的学过也欠缺实战经验。学习Python全凭兴趣爱好,通过《Python编程快速上手++让繁琐工作自动化》一书入门。

开启《人生苦短,我用Python》系列博文,主要是为了记录自己在Python编程实践过程中所积累的知识和经验,同时希望也能将我的一些经验分享给有需要的人。文中的语句均为经过验证的语句,但由于缺乏系统的学习,难免存在错误,还请各位包涵并指出。

需求:本人供职于甲方,网络设备维保商会定期通过巡检工具,抓取网络设备状态。描述每台网络设备状态的文件,会分别保存到以网络设备IP地址和Hostname为文件夹名称的文件夹中。如下图:(关于通过python实现抓取网络设备状态的功能,可通过netmiko库连接设备,登陆后执行相关操作,该功能目前我已开发完成。可以在之后整理成文章发布到博客。)

在这样的,情况下,如果想要将不同网络设备的同一类信息集合在一起,例如:配置信息。需要在每台设备的文件夹中找到对应的文件,复制到新的文件夹中,更改名称。这一类操作,从寻找->复制->粘贴->改名这一系列操作较为繁琐且无技术含量,浪费工作时间。所以想到,用python脚本实现这部分工作的自动化。

本次以,抓取不同网络设备的配置文件为例,熟悉思科设备的人都知道,在思科设备上,执行show running-config。完成当前运行配置的收集工作。所以,目前,关于思科设备,每个以设备名称命名的文件夹中,都有一个show running-config的配置文件,我需要做的就是,找到这个文件,复制这个文件到新的文件夹,并将复制过来的文件改名为其原属文件夹的名称。

在这里,我们主要用到三个python模块。

  1. OS模块—用于对文件、文件夹进行遍历等操作。
  2. shutil模块—用于对文件进行复制操作。
  3. datetime模块—该模块不是必须,本人习惯用该模块创建带有脚本执行日期的文件或文件夹。

先来看整体语句:

def findFile(path,example):import os,shutil,datetime#print(path)#print(example)dayTime = datetime.datetime.now().strftime('%Y_%m_%d')i=0if os.path.exists('.\\'+dayTime+example)!=True:os.makedirs('.\\'+dayTime+example)for fPath,fDirs,fFile in os.walk(path):for f in fFile:if f == example:#print(fPath)print(os.path.join(fPath,f))srcfile = os.path.join(fPath,f)newFile=os.path.basename(fPath)#print(newFile)dstfile = '.\\'+dayTime+example+'\\'+newFile+'.txt'shutil.copyfile(srcfile,dstfile)i=i+1else:continueprint('已完成目录'+path+'的检索')i=str(i)print('共找到匹配文件'+i+'个')path='.\\A公司巡检'
example='show running-config.txt'
findFile(path,example)

针对其中的重点语句进行讲解

os.walk(path)

path代表将要遍历的目录,os.walk()会返回三个元素的元组(fPath,fDirs,fFile),分别代表path下的所有路径,该路径下的目录列表和该路径下的文件列表。

例如我想遍历下面这个目录:

语句如下:

import os
for fPath,fDirs,fFile in os.walk('.\\venv'):print('Path:%s'%fPath)print('Dir:%s'%fDirs)print('File:%s'%fFile)

例如,第一次会遍历venv这个目录本身,列出目录下的目录和文件,结果如下:

Path:.\venv
Dir:['Include', 'Lib', 'Scripts']
File:['pyvenv.cfg']

接下来,会遍历Inclue这个目录,列出该目录下的目录和文件,结果如下:

Path:.\venv\Include
Dir:[]
File:[]

可见,Inclue这个目录下,没有其他目录,则Inclue的遍历完成。会继续遍历Lib这个目录,如下:

语句执行结果,如下:

Path:.\venv\Lib
Dir:['site-packages', 'tcl8.6']
File:[]
Path:.\venv\Lib\site-packages
Dir:['pip-9.0.1-py3.4.egg']
File:['easy-install.pth', 'setuptools-28.8.0-py3.4.egg', 'setuptools.pth']

可见,os.walk()默认会从上到下依次遍历目录下所有子目录和文件,若有子目录,再遍历子目录下的目录和文件,一直进行下去,直到所有的目录都被遍历过。每一次遍历会返回正在遍历的路径,该路径下的目录列表和文件列表。

回到程序本身,利用os.walk()遍历指定路径下的所有目录,再确认遍历的目录对应的文件列表中,是否包含与我想查找的文件相匹配的文件。具体实现语句如下:

    for fPath,fDirs,fFile in os.walk(path):for f in fFile:if f == example:

若找到匹配的文件,则获取改文件所在路径,同时获取该文件所在文件夹的名称,作为复制后的文件的名称。最后将源文件进行复制,并改名为其原属文件夹的名称,实现语句如下:

srcfile = os.path.join(fPath,f)
newFile=os.path.basename(fPath)
dstfile = '.\\'+dayTime+example+'\\'+newFile+'.txt'
shutil.copyfile(srcfile,dstfile)

这样便完成了需求中最重要的部分,找到源文件->复制->粘贴->改名。

该语句的执行结果如下:

当然,你也可以用这段语句实现搜索指定文件夹,指定文件的功能。

后续,可以将该功能通过flask网页呈现,或通过Tkinter实现GUI。之后将在其他文章描述这部分功能的实现。

这篇关于人生苦短,我用Python(一)—Python实现指定文件夹中同类文档的收集工作的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/508588

相关文章

SpringBoot3实现Gzip压缩优化的技术指南

《SpringBoot3实现Gzip压缩优化的技术指南》随着Web应用的用户量和数据量增加,网络带宽和页面加载速度逐渐成为瓶颈,为了减少数据传输量,提高用户体验,我们可以使用Gzip压缩HTTP响应,... 目录1、简述2、配置2.1 添加依赖2.2 配置 Gzip 压缩3、服务端应用4、前端应用4.1 N

SpringBoot实现数据库读写分离的3种方法小结

《SpringBoot实现数据库读写分离的3种方法小结》为了提高系统的读写性能和可用性,读写分离是一种经典的数据库架构模式,在SpringBoot应用中,有多种方式可以实现数据库读写分离,本文将介绍三... 目录一、数据库读写分离概述二、方案一:基于AbstractRoutingDataSource实现动态

Python FastAPI+Celery+RabbitMQ实现分布式图片水印处理系统

《PythonFastAPI+Celery+RabbitMQ实现分布式图片水印处理系统》这篇文章主要为大家详细介绍了PythonFastAPI如何结合Celery以及RabbitMQ实现简单的分布式... 实现思路FastAPI 服务器Celery 任务队列RabbitMQ 作为消息代理定时任务处理完整

Python Websockets库的使用指南

《PythonWebsockets库的使用指南》pythonwebsockets库是一个用于创建WebSocket服务器和客户端的Python库,它提供了一种简单的方式来实现实时通信,支持异步和同步... 目录一、WebSocket 简介二、python 的 websockets 库安装三、完整代码示例1.

揭秘Python Socket网络编程的7种硬核用法

《揭秘PythonSocket网络编程的7种硬核用法》Socket不仅能做聊天室,还能干一大堆硬核操作,这篇文章就带大家看看Python网络编程的7种超实用玩法,感兴趣的小伙伴可以跟随小编一起... 目录1.端口扫描器:探测开放端口2.简易 HTTP 服务器:10 秒搭个网页3.局域网游戏:多人联机对战4.

Java枚举类实现Key-Value映射的多种实现方式

《Java枚举类实现Key-Value映射的多种实现方式》在Java开发中,枚举(Enum)是一种特殊的类,本文将详细介绍Java枚举类实现key-value映射的多种方式,有需要的小伙伴可以根据需要... 目录前言一、基础实现方式1.1 为枚举添加属性和构造方法二、http://www.cppcns.co

使用Python实现快速搭建本地HTTP服务器

《使用Python实现快速搭建本地HTTP服务器》:本文主要介绍如何使用Python快速搭建本地HTTP服务器,轻松实现一键HTTP文件共享,同时结合二维码技术,让访问更简单,感兴趣的小伙伴可以了... 目录1. 概述2. 快速搭建 HTTP 文件共享服务2.1 核心思路2.2 代码实现2.3 代码解读3.

使用C#代码在PDF文档中添加、删除和替换图片

《使用C#代码在PDF文档中添加、删除和替换图片》在当今数字化文档处理场景中,动态操作PDF文档中的图像已成为企业级应用开发的核心需求之一,本文将介绍如何在.NET平台使用C#代码在PDF文档中添加、... 目录引言用C#添加图片到PDF文档用C#删除PDF文档中的图片用C#替换PDF文档中的图片引言在当

详解C#如何提取PDF文档中的图片

《详解C#如何提取PDF文档中的图片》提取图片可以将这些图像资源进行单独保存,方便后续在不同的项目中使用,下面我们就来看看如何使用C#通过代码从PDF文档中提取图片吧... 当 PDF 文件中包含有价值的图片,如艺术画作、设计素材、报告图表等,提取图片可以将这些图像资源进行单独保存,方便后续在不同的项目中使

MySQL双主搭建+keepalived高可用的实现

《MySQL双主搭建+keepalived高可用的实现》本文主要介绍了MySQL双主搭建+keepalived高可用的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录一、测试环境准备二、主从搭建1.创建复制用户2.创建复制关系3.开启复制,确认复制是否成功4.同