从Excel读取文件名并将其从指定目录下的文件复制到新目录

由于一些数据是以CSV, excel存放,想从数据中选取一些数据,偷个懒就写了个从excel中获取数据名,并在指定目录中寻找到并将其复制到新的目录下的小脚本。
(1)使用pandas读取excel
(2)python的os模块查找自定根目录下所有文件中是否存在目标文件
(3)使用shutil模块对文件进行复制操作

excel文件如下:
excel
存放数据的路径:
dir

代码:

#!/usr/bin/env python3
import os, shutil
import pandas as pd


def findpath(file_dir, file_name):
    '''
    
    :param file_dir: the root
    :param file_name: target file name
    :return: the path of target file
    '''
    for root, dirs, files in os.walk(file_dir):
        # print(root)  # 当前目录路径
        # print(dirs)  # 当前路径下所有子目录
        # print(files)  # 当前路径下所有非目录子文件
        if file_name in files:
            print(file_name, 'in', root)
            cur_file_path = root + '//' + file_name
            return cur_file_path
    print('No such file!')
    return None


if __name__ == '__main__':
    xlsx_path = 'D:/Research/record_of_heart_sound/PhysioNet_Database/special test use/random_sample.xlsx'
    data_frame=pd.read_excel(xlsx_path)
    # where the data store
    target_path = 'D:/Research/record_of_heart_sound/PhysioNet_Database'
    file_name = []
    for x in data_frame['Challenge record name']:
        file_name.append(x + '.wav')
    file_path = []
    for x in file_name:
        # file_path.append(findpath(target_path, x))
        # target file path
        srcFile = findpath(target_path, x)
        # new directory
        targetFile = 'D:/Research/record_of_heart_sound/PhysioNet_Database/special test use/' + x
        # copy to new directory
        shutil.copyfile(srcFile, targetFile)


参考:

python读取excel文件的三种方法
pandas入门 之read_excel()和to_excel()函数解析
python获取当前路径
python 获取当前文件夹下所有文件名

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
网管教程 从入门到精通软件篇 ★一。★详细的xp修复控制台命令和用法!!! 放入xp(2000)的光盘,安装时候选R,修复! Windows XP(包括 Windows 2000)的控制台命令是在系统出现一些意外情况下的一种非常有效的诊断和测试以及恢复系统功能的工具。小编的确一直都想把这方面的命令做个总结,这次辛苦老范给我们整理了这份实用的秘笈。   Bootcfg   bootcfg 命令启动配置和故障恢复(对于大多数计算机,即 boot.ini 文件)。   含有下列参数的 bootcfg 命令仅在使用故障恢复控制台时才可用。可在命令提示符下使用带有不同参数的 bootcfg 命令。   用法:   bootcfg /default  设置默认引导项。   bootcfg /add    向引导列表添加 Windows 安装。   bootcfg /rebuild  重复全部 Windows 安装过程并允许用户选择要添加的内容。   注意:使用 bootcfg /rebuild 之前,应先通过 bootcfg /copy 命令备份 boot.ini 文件。   bootcfg /scan    扫描用于 Windows 安装的所有磁盘并显示结果。   注意:这些结果被静态存储,并用于本次会话。如果在本次会话期间磁盘配置发生变化,为获得更的扫描,必须先重启动计算机,然后再次扫描磁盘。   bootcfg /list   列出引导列表已有的条目。   bootcfg /disableredirect 在启动引导程序禁用重定向。   bootcfg /redirect [ PortBaudRrate] |[ useBiosSettings]   在启动引导程序通过指定配置启用重定向。   范例: bootcfg /redirect com1 115200 bootcfg /redirect useBiosSettings   hkdsk   创建并显示磁盘的状态报告。Chkdsk 命令还可列出并纠正磁盘上的错误。   含有下列参数的 chkdsk 命令仅在使用故障恢复控制台时才可用。可在命令提示符下使用带有不同参数的 chkdsk 命令。   vol [drive:] [ chkdsk [drive:] [/p] [/r]   参数  无   如果不带任何参数,chkdsk 将显示当前驱动器的磁盘状态。 drive: 指定要 chkdsk 检查的驱动器。 /p   即使驱动器不在 chkdsk 的检查范围内,也执行彻底检查。该参数不对驱动器做任何更改。 /r   找到坏扇区并恢复可读取的信息。隐含着 /p 参数。   注意 Chkdsk 命令需要 Autochk.exe 文件。如果不能在启动目录(默认为 %systemroot%System32)找到该文件,将试着在 Windows 安装 CD 找到它。如果有多引导系统的计算机,必须保证是在包含 Windows 的驱动器上使用该命令。 Diskpart   创建和删除硬盘驱动器上的分区。diskpart 命令仅在使用故障恢复控制台时才可用。   diskpart [ /add |/delete] [device_name |drive_name |partition_name] [size]   参数 无   如果不带任何参数,diskpart 命令将启动 diskpart 的 Windows 字符模式版本。   /add   创建的分区。   /delete   删除现有分区。   device_name   要创建或删除分区的设备。设备称可从 map 命令的输出获得。例如,设备称:   DeviceHardDisk0   drive_name   以驱动器号表示的待删除分区。仅与 /delete 同时使用。以下是驱动器称的范例:   D:   partition_name   以分区称表示的待删除分区。可代替 drive_name 使用。仅与 /delete 同时使用。以下是分区称的范例:   DeviceHardDisk0Partition1    大小   要创建的分区大小,以兆字节 (MB)表示。仅与 /add 同时使用。   范例   下例将删除分区: diskpart /delete Device HardDisk0 Partition3 diskpart /delete F:   下例将在硬盘上添加一个 20 MB 的分区:   diskpart /add Device HardDisk0 20   Fixboot

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值