删除项目与 [System.IO.File]::Delete()
Remove-Item Vs [System.IO.File]::Delete()
我在 Azure Runbook 中有以下代码:
$pathToDownloadedBlob = 'C:\depId-20150904032522\SevenZipSharp.dll'
if ((Test-Path $pathToDownloadedBlob) -eq $true)
{
try
{
Remove-Item -Path $pathToDownloadedBlob
}
catch
{
write-error "Could not delete $pathToDownloadedBlob. - $($error[0])"
exit
}
}
当我使用 Remove-Item
时出现此错误:
4/7/2015 2:14:14 PM, Error: Remove-Item : The converted JSON string is in bad format.
At DavidTest:45 char:45
+
+ CategoryInfo : InvalidOperation: (System.Unauthor... Boolean force):ErrorRecord) [Remove-Item],
InvalidOperationException
+ FullyQualifiedErrorId : JsonStringInBadFormat,Microsoft.PowerShell.Commands.RemoveItemCommand
当我改用 [System.IO.File]::Delete($using:path)
时,出现此错误:
4/7/2015 2:22:48 PM, Error: Exception calling "Delete" with "1" argument(s): "Access to the path 'C:\Deployment\SevenZipSharp.dll' is denied."
At DavidTest:46 char:46
+
+ CategoryInfo : NotSpecified: (:) [], MethodInvocationException
+ FullyQualifiedErrorId : UnauthorizedAccessException
我知道我没有删除该文件的权限。
但是,为什么当我使用 Remove-Item
时它会抱怨 JSON 字符串?
编辑:
请注意,这仅发生在 Azure 自动化中。但是我无法在本地的 Powershell ISE 中真正复制它,因为我有权删除我想删除的文件。
更新:我刚刚意识到这只发生在 .dll 文件上。如果我尝试删除 .7z 文件,它工作正常。
我想这是由于在 PowerShell 工作流上下文和 InlineScript 工作流之间传递的对象的序列化/反序列化 Activity,它默认在单独的进程中运行。
您是总是传递 [System.String]
,还是有时传递 [System.IO.FileInfo]
对象?如果是后者,那么您可能希望引用 FullName
属性,而不是将对象本身传递给 Remove-Item
.
我不是 100% 确定这就是您 运行 的目标,但值得讨论。
顺便说一下,作为最佳做法,请始终明确命名您的参数,以便其他人了解您在做什么。您对 Remove-Item
的调用不包括名称中的 -Path
参数,因为它的位置为 0。当然,当您寻求帮助时,认为这不是一件好事.最好详细一点。
希望这至少能有所帮助。顺便问一下,这个问题是 Azure Automation Runbook 独有的,还是在本地执行的 PowerShell 工作流中也存在?
编辑:这段代码在本地对我来说似乎工作得很好。
workflow test {
$Path = 'C:\dsc\srv01.xml';
InlineScript { Remove-Item -Path $using:Path; };
}
test
我在 Azure Runbook 中有以下代码:
$pathToDownloadedBlob = 'C:\depId-20150904032522\SevenZipSharp.dll'
if ((Test-Path $pathToDownloadedBlob) -eq $true)
{
try
{
Remove-Item -Path $pathToDownloadedBlob
}
catch
{
write-error "Could not delete $pathToDownloadedBlob. - $($error[0])"
exit
}
}
当我使用 Remove-Item
时出现此错误:
4/7/2015 2:14:14 PM, Error: Remove-Item : The converted JSON string is in bad format.
At DavidTest:45 char:45
+
+ CategoryInfo : InvalidOperation: (System.Unauthor... Boolean force):ErrorRecord) [Remove-Item],
InvalidOperationException
+ FullyQualifiedErrorId : JsonStringInBadFormat,Microsoft.PowerShell.Commands.RemoveItemCommand
当我改用 [System.IO.File]::Delete($using:path)
时,出现此错误:
4/7/2015 2:22:48 PM, Error: Exception calling "Delete" with "1" argument(s): "Access to the path 'C:\Deployment\SevenZipSharp.dll' is denied."
At DavidTest:46 char:46
+
+ CategoryInfo : NotSpecified: (:) [], MethodInvocationException
+ FullyQualifiedErrorId : UnauthorizedAccessException
我知道我没有删除该文件的权限。
但是,为什么当我使用 Remove-Item
时它会抱怨 JSON 字符串?
编辑: 请注意,这仅发生在 Azure 自动化中。但是我无法在本地的 Powershell ISE 中真正复制它,因为我有权删除我想删除的文件。
更新:我刚刚意识到这只发生在 .dll 文件上。如果我尝试删除 .7z 文件,它工作正常。
我想这是由于在 PowerShell 工作流上下文和 InlineScript 工作流之间传递的对象的序列化/反序列化 Activity,它默认在单独的进程中运行。
您是总是传递 [System.String]
,还是有时传递 [System.IO.FileInfo]
对象?如果是后者,那么您可能希望引用 FullName
属性,而不是将对象本身传递给 Remove-Item
.
我不是 100% 确定这就是您 运行 的目标,但值得讨论。
顺便说一下,作为最佳做法,请始终明确命名您的参数,以便其他人了解您在做什么。您对 Remove-Item
的调用不包括名称中的 -Path
参数,因为它的位置为 0。当然,当您寻求帮助时,认为这不是一件好事.最好详细一点。
希望这至少能有所帮助。顺便问一下,这个问题是 Azure Automation Runbook 独有的,还是在本地执行的 PowerShell 工作流中也存在?
编辑:这段代码在本地对我来说似乎工作得很好。
workflow test {
$Path = 'C:\dsc\srv01.xml';
InlineScript { Remove-Item -Path $using:Path; };
}
test