Robocopy(或xcopy)从文件中读取?

时间:2011-01-25 13:43:58

标签: windows file xcopy robocopy

所以我有一些excel表,其中包含源自单个根目录的目录。反正有没有robocopy(或类似的程序)读取excel表作为输入只复制选定的文件?

这是电子表格的格式:

NMMC c6 31b5ac6c-1377-4a86-90a0-73c6335907e3.IMG
NMMC 2e 1da3d2ec-526f-479a-9c09-90cb2cfad0b6.IMG
NMMC 8a f77168ad-2f35-490c-a2a8-25e9fa4ac0ea.IMG
NMMC 2f fc2162f8-7548-4921-b722-5899cbe54641.IMG
NMMC fc 1fe09fcd-3861-4de8-8bfd-4510ffa8f29c.IMG
hcri001 1b  243161b4-eef0-4d5c-9e42-dcea6772afdd.IMG
hcri001 a7  7e60ba72-fb8f-4d65-ae34-92b034c10e2e.IMG
hcri001 84  7934584f-7bc8-4450-bf6d-da58ac2ebb1a.IMG
hcri001 1a  cda461ab-fe9d-4b4f-87bf-43dab9dd8644.IMG
hcri001 2b  4f2c02b6-31c6-4d8b-975e-591778bcdfef.IMG
ICPS    8a  2aca38a8-4133-4972-a03f-8c3c15654df3.IMG
ICPS    89  8338f897-76c0-4f6f-9ae5-3b4c7e8a302c.IMG
ICPS    30  d9dba300-6c14-4484-a147-bccb9dd15aa3.IMG

我想将这些文件复制到具有相同结构的另一个文件系统(例如,如果图像来自C:\Apps\Test\Site\NMMC\c6\31b5ac6c-1377-4a86-90a0-73c6335907e3.IMG,那么我需要将其复制到Z:\Apps\FileSystem\NMMC\c6\31b5ac6c-1377-4a86-90a0-73c6335907e3.IMG

这可能吗?

由于

编辑以消除混乱

4 个答案:

答案 0 :(得分:1)

如果您想避免编写Office Interop代码,我的建议是执行以下操作:

首先,在Excel中将数据保存为CSV文件到路径c:\ temp \ foo.csv。这将创建一个如下所示的数据文件:

NMMC,2e,1da3d2ec-526f-479a-9c09-90cb2cfad0b6.IMG
NMMC,8a,f77168ad-2f35-490c-a2a8-25e9fa4ac0ea.IMG
NMMC,2f,fc2162f8-7548-4921-b722-5899cbe54641.IMG
NMMC,fc,1fe09fcd-3861-4de8-8bfd-4510ffa8f29c.IMG

接下来,打开命令提示符并编写以下命令:

for /f "delims=, tokens=3" %i in ( c:\temp\foo.csv ) do echo %i

这将输出所有文件名(以及文件名)。一旦你开心这就行了,然后将“echo%i”更改为你想要的任何xcopy命令。

答案 1 :(得分:0)

使用文本编辑器创建批处理文件或shell脚本。例如,您可以查找/替换以便bat文件包含以下内容:

copy c:\31b5ac6c-1377-4a86-90a0-73c6335907e3.IMG
copy c:\1da3d2ec-526f-479a-9c09-90cb2cfad0b6.IMG
copy c:\f77168ad-2f35-490c-a2a8-25e9fa4ac0ea.IMG
copy c:\fc2162f8-7548-4921-b722-5899cbe54641.IMG
copy c:\1fe09fcd-3861-4de8-8bfd-4510ffa8f29c.IMG

答案 2 :(得分:0)

您可以尝试使用PowerShell的COM自动化来读取Excel文件并将这些行提供给copy,xcopy或robocopy。

我无法举例说明在实践中如何做到这一点,我的powershell-fu还不够强大。谷歌可能是你的朋友。

答案 3 :(得分:0)

好的,我想我已经拥有了它。这是我正在运行的命令提示符脚本:

for /f "delims=, tokens=1,2,3" %i in ( D:\foo.csv ) do xcopy /i /y "Z:\%i\%j\%k" "D:\%i\%j\%k"

这正是我想要的,但是对于每个文件,它试图复制一个提示符,询问我它是文件还是目录。有没有告诉xcopy他们是所有文件?我认为这是我/我做了什么,但这似乎无法抑制提示。