powershell没有看到文件系统的变化 - “无法找到路径”

时间:2015-01-21 02:41:28

标签: windows perl powershell powershell-v3.0

我编写了一个powershell脚本,可以从Dynamics NAV实例中导出一堆文件。它调用了我写的perl脚本,然后将所有文件分成单个对象,并将它们放在我在perl中创建的目录下的子目录中。然后powershell脚本尝试将文件复制到另一个目录,然后失败。

Powershell会生成目录名称:

$datestamp = get-date -f MM-dd-yyyy_HH_mm_ss
$dumpdir = "\temp\nav_export\" + $env:username + "\" + $servicetier + "~" + $database + "~" + $datestamp;

然后powershell做了很多工作正常的东西,调用了perl脚本($ servicetier和$ database在脚本的前面定义):

& c:\navgit\split-objects.pl $servicetier $database $datestamp

perl继续创建目录并正确拆分文件:

use strict;
use warnings;
use File::Path qw(make_path remove_tree);

my $username = getlogin || getpwuid($<);
my $servicetier = $ARGV[0];
my $database = $ARGV[1];
my $datestamp = $ARGV[2];
undef @ARGV;

my $work_dir = "/temp/nav_export";
my $objects_dir = "$work_dir/$username/objects";
my $export_dir = "$work_dir/$username/$servicetier~$database~$datestamp";

print "Objects from $servicetier~$database being exported to $export_dir\n";

make_path("$export_dir/Page", "$export_dir/Codeunit", "$export_dir/MenuSuite", "$export_dir/Query", "$export_dir/Report", "$export_dir/Table", "$export_dir/XMLport");

chdir $objects_dir or die "Could not change to $objects_dir: $!";

<does all of the filehandling and parsing>

Control返回到powershell脚本,该脚本尝试完成:

Copy-Item -Path $dumpdir -Destination $cwd -Force -Recurse

但是这会引发错误:

Copy-Item : Cannot find path 'C:\temp\nav_export\danielj\cen-dev-erp-st1~JustFoodERP-PROTO~01-20-2015_19_26_50' because it does not exist.
At C:\navgit\nav-export.ps1:175 char:1
+ Copy-Item -Path $dumpdir -Destination $cwd -Force -Recurse
+ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    + CategoryInfo          : ObjectNotFound: (C:\temp\nav_exp...0-2015_19_26_50:String) [Copy-Item], ItemNotFoundException
    + FullyQualifiedErrorId : PathNotFound,Microsoft.PowerShell.Commands.CopyItemCommand

我正在尝试复制的目录确实存在。但是PowerShell看不到它!我添加了一些代码来列出父目录的内容:

Copy-Item -Path $dumpdir -Destination $cwd -Force -Recurse
Write-Host "Copy-Item -Path $dumpdir -Destination $cwd -Force -Recurse"
$test = "C:\temp\nav_export\$env:username"
Get-ChildItem $test -Force

Copy-Item -Path \temp\nav_export\danielj\cen-dev-erp-st1~JustFoodERP-PROTO~01-20-2015_19_26_50 -Destination C:\Users\danielj\erp\ -Force -Recurse

    Directory: C:\temp\nav_export\danielj

Mode                LastWriteTime     Length Name                                                                                                                        
----                -------------     ------ ----                                                                                                                        
d----         1/20/2015   6:32 PM            cen-dev-erp-st1~JustFoodERP-PROTO~01-20-2015_18_32_33                                                                       
d----         1/20/2015   7:08 PM            cen-dev-erp-st1~JustFoodERP-PROTO~01-20-2015_19_08_49                                                                       
d----         1/19/2015   1:07 PM            cen-dev-erp-st1~JustFoodERP-PROTO~20150119-130747                                                                           
d----         1/20/2015   7:26 PM            logs                                                                                                                        
d----         1/20/2015   7:26 PM            objects                                                                                                                     
-a---         1/20/2015   7:26 PM        309 objects.bat                                                                                                                 
-a---         1/20/2015   1:41 PM        436 soap_envelope.txt

如果我从脚本外部进行目录列表,那就是:

PS C:\Users\danielj\erp> $test = "C:\temp\nav_export\$env:username"
Get-ChildItem $test -Force

Directory: C:\temp\nav_export\danielj


Mode                LastWriteTime     Length Name                                                                                                                        
----                -------------     ------ ----                                                                                                                        
d----         1/20/2015   6:32 PM            cen-dev-erp-st1~JustFoodERP-PROTO~01-20-2015_18_32_33                                                                       
d----         1/20/2015   7:08 PM            cen-dev-erp-st1~JustFoodERP-PROTO~01-20-2015_19_08_49                                                                       
d----         1/20/2015   7:26 PM            cen-dev-erp-st1~JustFoodERP-PROTO~01-20-2015_19_26_50                                                                       
d----         1/19/2015   1:07 PM            cen-dev-erp-st1~JustFoodERP-PROTO~20150119-130747                                                                           
d----         1/20/2015   7:26 PM            logs                                                                                                                        
d----         1/20/2015   7:26 PM            objects                                                                                                                     
-a---         1/20/2015   7:26 PM        309 objects.bat                                                                                                                 
-a---         1/20/2015   1:41 PM        436 soap_envelope.txt                                                                                                           

在perl完成后,我尝试从主PowerShell脚本调用外部脚本,结果是一样的。

为什么powershell看不到perl脚本创建的目录或文件?更重要的是,我怎么能这样做呢?

2 个答案:

答案 0 :(得分:0)

你确定所有程序按照你所假设的顺序执行吗?

尝试像这样启动你的perl脚本:

& c:\navgit\split-objects.pl $servicetier $database $datestamp | Out-Null

确保在PowerShell执行脚本的其余部分时终止Perl部分。

答案 1 :(得分:0)

我最初只是在powershell中创建目录。没理由它必须在perl脚本中创建。

它仍然很高兴知道为什么它没有像我预期的那样工作。