20181205Python 自动化笔试题,挑战你的知识库

本贴最后更新于 354 天前,其中的信息可能已经时移俗易

1:获取当前目录下所有文件,然后做如下处理:

  1. 文件名去重复。
  2. 选出文件大于 10m 的
  3. 获取到文件的 md5 值,然后利用这个 md5 值对文件名进行重命名(其中 md5 代表一个文件属性)
  4. 打印出最后的符合条件的所有文件名

温馨提示:

  1. 我们是要获取所有的文件 而不是目录
  2. 去重复不是删除文件,而是对重复的文件名进行重命名
  3. 想办法获取文件的 md5 值
  4. 最好是函数的形式实现哦
1 操作
huahua 在 2020-08-07 21:52:58 更新了该帖
18 回帖
请输入回帖内容 ...
  • huahua

    还有小伙子小妹纸要提交吗??
    这绝对是实力挑战赛

  • 其他回帖
  • emma
    import os
    import hashlib
    def get_md5(file_path):#计算md5值
        with open(file_path, 'rb') as f:
            md5 = hashlib.md5()
            while True:
                b=f.read(8096)#分段读取
                if not b:
                    break   #如果读取结束了就跳出循环
                md5.update(b)
            hash = md5.hexdigest()
        return hash   #返回文件的md5值
    
    file_list = []
    new_file=[]
    name=[]
    def find_file(path): #获取所有的文件,并筛选出大于10M的文件
        if os.path.isdir(path)==True:
            for items in os.listdir(path):
                new_path=os.path.join(path,items)
                find_file(new_path)
        else:
            if os.path.getsize(path) >=10*1024*1024:
                file_list.append(path)
        return file_list
    
    
    
    def find_name(file): #找到重名的文件并修改
        new_path=[]
        name=[]
        for items in file:
            name.append(os.path.split(items))
        for i in range(len(name)-1):
            for j in range(i+1,len(name)):
                if name[i][-1]==name[j][-1]:
                    new_path.append(os.path.join(name[i][0],name[i][-1]))
                    new_path.append(os.path.join(name[j][0],name[j][-1]))
        for items in new_path: #new_path里面是所有重名的文件路径集合
            md5=get_md5(items)
            file=os.path.split(items)[-1]#获取文件名
            newname=md5+'.'+file.split('.')[-1]#拼接新文件名
            os.rename(items,os.path.join(os.path.split(items)[0],newname)) #重命名
    
    path=os.getcwd()
    print(path)
    file=find_file(path)
    find_name(file)
    
  • Monica711
    # -*- coding: utf-8 -*-
    # @Time  : 2018/12/5 10:21
    # @Author : Monica
    # @Email : 498194410@qq.com
    # @File  : os_practice.py
    
    import os
    import hashlib
    
    allfiles = []
    templist = {}
    end_file = []
    
    
    class GetFlie:
        def __init__(self, dirpath):
            self.dirpath = dirpath
    
        def get_all_file(self):
            # 通过os.walk获取目录下的所有文件名
            for root, dirs, files in os.walk(self.dirpath):
                for file in files:
                    # 判断size
                    size = os.path.getsize(os.path.join(root, file))
                    if size >= 10485760:
                        # 文件名添加到allfiles列表里
                        allfiles.append(os.path.join(root, file))
            # 重命名
            for i in range(len(allfiles)):
                # 如果md5在字典的key已存在
                if self.get_md5(allfiles[i]) in templist.keys():
                    templist[self.get_md5(allfiles[i]) + str(i)] = allfiles[i].split(".")[0] + str(i) + "." + allfiles[i].split(".")[-1]
                else:
                    templist[self.get_md5(allfiles[i])] = allfiles[i]
            # 最后的文件
            for file in templist.values():
                end_file.append(file)
    
            return end_file
    
        @staticmethod
        def get_md5(filename):
            f = open(filename, 'rb')
            m1 = hashlib.md5()
            m1.update(f.read())
            hash_code = m1.hexdigest()
            f.close()
            md5 = str(hash_code).lower()
            return md5
    
    if __name__ == '__main__':
        path = r'I:\lesson_practice\tool'
        print(GetFlie(path).get_all_file())
    
    
  • mmklyz

    虽然好多写答案的了,还是把自己写的代码贴上来,毕竟写了很久。虽然判断重名的还没有实现

    import os
    import hashlib
    
    class Test:
        #获取文件对应的md5
        def get_md5(self,path,file_name):
            with open(os.path.join(path,file_name),'rb') as f:
                md5obj=hashlib.md5()
                md5obj.update(f.read())
                hash=md5obj.hexdigest()
            return hash
    
        #获取文件大小的函数,默认获取到的单位是byte
        def get_size(self,file_path):
            fsize=os.path.getsize(file_path)
            fmz=fsize/1024                   #转换为kb
            return round(fmz,2)
    
        #过滤重名文件并重命名
        def rename(self,path):
            list = []  # 定义一个空列表用来存放文件名
            i = 1  # 重名文件-文件名自增
            for root, dirs, files in os.walk(path):
                for file in files:
                    if file not in list:  # 判断文件名是否已经在列表中,如果不在,则直接追加
                        list.append(file)
                    else:  # 如果在,则重命名后追加
                        new_name = "test000" + str(i) + ".py"  # 新文件名命名组合
                        os.rename(file, new_name)
                        list.append(new_name)
                        i += 1
                        # print("每一次的list是{}".format(list))
            return list  # 返回重命名后的文件集合
    
        # 获取目录下的所有文件,并调用get——md5函数
        def allfile(self,basepath):
            # 判断是否有重名文件并重命名,调用rename函数
            self.rename(basepath)
            list1=[]
            for root,dirs,files in os.walk(basepath):
                for file in files:
                    #获取文件的大写
                    fsize=self.get_size(os.path.join(root,file))
                    if fsize>1:                                     #如果文件大于1kb,则修改名称
                        md5_name = self.get_md5(root, file)+".py"  #md5名字:root:文件对应目录;file:文件名
                        os.rename(file,md5_name)                    #将大于1kb的文件重命名
                        print("符合条件的所有文件是{},文件大小是{}kb".format(file,fsize))
                    else:
                        # print("文件{}太小,大小是{}byte".format(file,fsize))
                        list1.append(file)
            print("小于1kb的文件集合是{}".format(list1))
    
    
    if __name__ == '__main__':
        path=os.getcwd()
        Test().allfile(path)
    
    

    1)一共 4 个方法:过滤重名文件并重命名,获取文件对应的 MD5,获取文件大小,获取文件列表(判断大小&重命名)
    2)主要用到了 os 库中的 os.path.getsize(), walk(), os.path.join(), os.rename() 函数。中间使用了 for 循环和 if 判断
    3)关于获取文件 md5 的代码是直接在网上搜的,自己看不太明白。

  • 查看更多回帖