1

所以我有一些 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

4 回答 4

1

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

首先,在 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 命令。

于 2011-01-25T13:57:55.230 回答
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
于 2011-01-25T13:49:03.947 回答
0

您可以尝试使用 PowerShell 的 COM 自动化来读取 Excel 文件并将这些行输入到 copy、xcopy 或 robocopy。

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

于 2011-01-25T13:57:34.483 回答
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 它们都是文件?我认为这就是 /i 所做的,但这似乎并没有抑制提示。

于 2011-01-25T20:40:55.297 回答