公司内部需求一个工具检索目录下的文件在另外的目录中使用次数, 用来优化包体的大小。

此代码效率并不高效, 另添加对应的 后缀检索。 用python 实现比较快速, 另还有缺点是只支持 utf-8 格式内容。

各位用到的可以自己摘一下。

(本人习惯使用c\c++,目前发现这种脚本类的确实实现方便,接口齐全, 我能想到的接口, 真的全都有, 用python 写工具, 应该是一个调试起来还可以的过程)

代码如下:

 #coding=utf-8

 import os
import sys
import time #private:
def checkSuffix(strFileName, strCompareSuffix):
strPreFileName = ''
strFileSuffix = ''
bIsCheckOk = False
strArray = strFileName.split('.')
if len(strArray) > 1:
strPreFileName = strArray[0]
strFileSuffix = strArray[1]
#print(strFileSuffix)
#print(strCompareSuffix)
if strCompareSuffix == '*' or strFileSuffix == strCompareSuffix:
bIsCheckOk = True
return bIsCheckOk, strPreFileName def readFileName(file_dir):
for root, dirs, files in os.walk(file_dir):
return files,dirs, root
return '', '', '' def findString(pathFile, findKey):
#print("open pathFile:", pathFile)
fp = open(pathFile, "r", encoding='utf-8')
strr = fp.read()
if(strr.find(findKey) != -1):
return True
return False def startFind(files, dirs, root, findKey, strSuffix):
for fileName in files:
try:
bIsCheckOk, strPreFileName = checkSuffix(fileName, strSuffix)
if bIsCheckOk == False:
#print("fileName", fileName, " is not suffx :", strSuffix)
continue
if(findString(root + "\\" + fileName, findKey)):
return True, fileName
except Exception as err:
continue for jj in dirs:
fi, di, ro = readFileName(root + jj)
bIsFind, fileName = startFind(fi, di, ro, findKey, strSuffix)
if(bIsFind == True):
return bIsFind, fileName
return False, '' #public:
def findUse(dirPath, findKey, strSuffix):
files, dirs, root = readFileName(dirPath)
return startFind(files, dirs, root, findKey, strSuffix) def getDirsFiles(dirPath):
dirfiles = [];
for root, dirs, files in os.walk(dirPath):
dirfiles += files;
return dirfiles def writeResult(strFileName, strWriteSign, list):
fp = open(strFileName, 'a+')
fp.write(strWriteSign)
#fp.writelines(list)
for str in list:
fp.write(str)
fp.write('\n')
fp.close() if __name__ == '__main__':
"""
findDir = u"E:\\mmo2018001\\artist\\open\\ui\\free\\"
findAimDir = u"E:\\mmo2018001\\artist\\open\\effect\\"
findsuffix = "prefab" # 哪些要搜索的文件的后缀
findAimsuffix = "*" # 搜索那些后缀的文件
"""
bt = time.clock() # 记录时间 findDir = sys.argv[1]
findAimDir = sys.argv[2]
findsuffix = sys.argv[3]
findAimsuffix = sys.argv[4] thisPath = os.getcwd()
print("this path is ", thisPath)
print(findDir)
print(findAimDir)
print(findsuffix)
print(findAimsuffix) dirFiles = getDirsFiles(findAimDir)
useFiles = []
notUseFiles = []
nLen = len(dirFiles)
i = 0
for filesName in dirFiles : bIsCheckOk, strPreFileName = checkSuffix(filesName, findsuffix)
if bIsCheckOk == True:
isFind, fileName = findUse(findDir, strPreFileName, findAimsuffix)
#print("filesName:\t", filesName, " \nIsFind:\t\t", isFind)
if(isFind):
useFiles.append(filesName)
else:
notUseFiles.append(filesName)
i += 1
p = round(i * 100 / nLen)
duration = round(time.clock() - bt, 2)
remaining = round(duration * 100 / (0.01 + p) - duration, 2)
print("进度:{0}%,已耗时:{1}s,预计剩余时间:{2}s".format(p, duration, remaining), end="\r") writePath = thisPath + "\\Result.txt"
try:
os.remove(writePath)
except Exception as err:
print(err)
writeResult(writePath, "***************NotUseFiles:***************\n", notUseFiles)
writeResult(writePath, "***************UseFiles:***************\n", useFiles)
useTime = time.clock() - bt
print("已完成 总耗时:", useTime)

python 检索文件内容工具的更多相关文章

  1. Linux中利用grep命令如何检索文件内容详解

    前言 Linux系统中搜索.查找文件中的内容,一般最常用的是grep命令,另外还有egrep命令,同时vi命令也支持文件内容检索.下面来一起看看Linux利用grep命令检索文件内容的详细介绍. 方法 ...

  2. Python 输出文件内容到网络端口

    Python 输出文件内容到网络端口 $ cat mySocketTest.py import sys import time import socket if __name__ == "_ ...

  3. python 修改文件内容

    python 修改文件内容 一.修改原文件方式 1 def alter(file,old_str,new_str): 2 """ 3 替换文件中的字符串 4 :param ...

  4. python实现文件搜索工具(简易版)

    在python学习过程中有一次需要进行GUI 的绘制, 而在python中有自带的库tkinter可以用来简单的GUI编写,于是转而学习tkinter库的使用. 学以致用,现在试着编写一个简单的磁文件 ...

  5. Linux中通过grep命令检索文件内容和指定内容前后几行

    原文链接: https://www.linuxidc.com/Linux/2017-11/148390.htm Linux系统中搜索.查找文件中的内容,一般最常用的是grep命令,另外还有egrep命 ...

  6. python改动文件内容,不须要read,write多个动作。

    python  要改动文件内容,经常使用 是先read.后write , 再 rename.非常不爽. 比方:须要 把       yuv_dir ="../HD/"   # &q ...

  7. python 修改文件内容3种方法

    原文链接:https://www.cnblogs.com/wc-chan/p/8085452.html def alter(file,old_str,new_str): ""&qu ...

  8. python ini文件内容的读取

    (1)新建一个项目,再次新建一个文件 test_cfg.ini (2)再次新建 get_test_cfg.py,用来读取/写入/更改 ini的文件内容 #!/usr/bin/env python # ...

  9. Python修改文件内容

    工作中要写个脚本来修改文件的内容,然后就写了一个刷子: #coding:utf8 import os def modify_file(old_file, new_version, old_versio ...

随机推荐

  1. HDU-4341 Gold miner 题解

    题目大意 黄金矿工的游戏,不过每个金块可以看做是质点,没有大小,给出每个金块的坐标.抓取所花费的时间(包括返回的时间),以及价值,其中有一些金块可能会共线.求在规定时间内所获得的最大价值. 样例 样例 ...

  2. Spring杂谈 | 从桥接方法到JVM方法调用

    前言 之所以写这么一篇文章是因为在Spring中,经常会出现下面这种代码 // 判断是否是桥接方法,如果是的话就返回这个方法 BridgeMethodResolver.findBridgedMetho ...

  3. 如何向这些CA来申请数字证书呢?

    申请的过程大致是: 1.自己本地先生成一对密匙,然后拿着自己的公匙以及其他信息(比如说企业名称啊什么的)去CA申请数字证书. 2.CA在拿到这些信息后,会选择一种单向Hash算法(比如说常见的MD5) ...

  4. 如何在微信小程序中使用阿里字体图标

    第一步:下载需要的字体图标 进入阿里图标官网http://iconfont.cn/搜索自己想要的图标. 如这里需要一个购物车的图标,流程为: 搜索“购物车”图标 --->  点击“添加入库”  ...

  5. 如何在Vim中的查找替换

    “%s/最/第二/g” 用vim的人都知道,这是把所有“最”替换成“第二”的意思.其实vim的查找替换功能非常强大,用的好可以极大提升效率. vim的查找替换命令如下所示:    :{作用范围}s/{ ...

  6. Python使用wxpy模块实现微信两两群组消息同步

    python使用wxpy模块提供的微信API接口实现两两群组的消息同步 安装模块: pip install wxpy 注意:需要同步的微信群需要保存到通讯录中 以下是自己闲来无事写的代码,暂时还存在以 ...

  7. Spring Boot 把 Maven 干掉了,拥抱 Gradle!

    在国外某社交网站上有一个关于迁移 Spring Boot 迁移 Maven 至 Gradle 的帖子: 该贴子上也有很多人质疑:Maven 用的好好的,为什么要迁移至 Gradle? 虽然该贴子只是说 ...

  8. Oracle调优之看懂Oracle执行计划

    @ 目录 1.文章写作前言简介 2.什么是执行计划? 3.怎么查看执行计划? 4.查看真实执行计划 5.看懂Oracle执行计划 5.1 查看explain 5.2 explain执行顺序 5.3 访 ...

  9. Linux环境下搭建禅道

    如何在Linux下搭建禅道 查看Linux版本信息 # cat /etc/redhat-release CentOS Linux release 7.4.1708 (Core) 禅道官网下载Linux ...

  10. Andrew Ng - 深度学习工程师 - Part 1. 神经网络和深度学习(Week 1. 深度学习概论)

     =================第1周 循环序列模型=============== ===1.1 欢迎来到深度学习工程师微专业=== 我希望可以培养成千上万的人使用人工智能,去解决真实世界的实际问 ...