2015-01-21 3 views
2

Я написал сценарий powershell, который экспортирует кучу файлов из экземпляра Dynamics NAV. Он вызывает perl-скрипт, который я также написал, а затем разбивает все файлы на отдельные объекты и вставляет их в подкаталоги в каталоге, создаваемом в perl. Затем скрипт powershell пытается скопировать файлы в другой каталог и не работает.powershell не видит изменения файловой системы - «не удается найти путь»

Powershell генерирует имя реж:

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

Тогда PowerShell делает кучу вещей, что работает отлично, и вызывает сценарий Perl ($ servicetier и $ базы данных определены ранее в сценарии):

& 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> 

управление возвращается в сценарий 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                           

Я попытался назвать внешний скрипт из главного сценария powershell после завершения perl, и результаты те же.

Почему в PowerShell не отображается каталог или файлы, созданные скриптом perl? И что еще более важно, как я могу это сделать?

+0

Выстрел в темноте - Это как-то связано с тильдой? Я не знаю, может быть, у него проблемы с этим персонажем. Раньше это означало что-то особенное ... ну это все равно ... старые имена файлов 8.3 – Matt

+0

@matt, nope. Я ценю предложение, но я уже искал для незаконных имен файлов Windows: '\ /: *? «< > |' | ' – user2969646

+0

О, это не противозаконно ... вы бы не нашли это далеко, если бы это было ... просто подумал, что, возможно, что-то было в этом. – Matt

ответ

0

Вы уверены, что все процедуры в том порядке, в котором вы его принимаете?

пытаются начать свой скрипт на языке Perl, как это:

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

Это гарантирует, что ваша часть Perl завершается, когда PowerShell выполнять остальную часть вашего сценария.

+0

Спасибо за предложение, но это дало мне ошибку 'Не удается запустить документ в середине конвейера: C: \ navgit \ split-objects.pl. В C: \ navgit \ nav-export.ps1: 102 char: 1 + & c: \ navgit \ split-objects.pl $ servicetier $ database $ datestamp $ startdir | Out-N ... ' – user2969646

0

В итоге я просто создал каталог в PowerShell. Нет причин, по которым это должно было быть создано в perl-скрипте.

Было бы неплохо узнать, почему это не сработало так, как я ожидал.

Смежные вопросы