截断天蓝色的存储文件目录/使用通配符后缀删除天蓝色的存储文件

时间:2019-01-21 10:54:46

标签: powershell azure-powershell azure-storage-files

我正在编写一个Powershell脚本,以启用每月清理azure文件共享中的文件的功能。

理想情况下,我希望一个脚本仅截断目录/文件位置。 但是会满足于分别删除每个文件。

每月大约加载20个文件,每个文件都有一个唯一的名称,并在文件名中包含后缀日期时间戳。例如 filename_20190121123515

我设法使用全名删除文件,但需要在日期时间后缀中使用通配符值。

我要实现的正确语法是什么?或者我该如何截断整个文件夹?

$context = New-AzStorageContext -StorageAccountName "AccountName" -SasToken 
"?sv=2015-12-11&si=bss-15D97F9B09D&sr=s&sig=xxxxxxxxxxxxxxxxxxxxx" 
Remove-AzStorageFile -ShareName "bss" -Path 
"root/Temp_Clean_up_test_Folder/FileName_%%%%%%%%%%%%%%.csv" -Context 
$context

$context = New-AzStorageContext -StorageAccountName "AccountName" -SasToken 
"?sv=2015-12-11&si=bss-15D97F9B09D&sr=s&sig=xxxxxxxxxxxxxxxxxxxxx" 
Remove-AzStorageFile -ShareName "bss" -Path 
"root/Temp_Clean_up_test_Folder/FileName_*" -Context $context

1 个答案:

答案 0 :(得分:0)

cmdlet Remove-AzStorageFile不支持通配符,您需要使用循环方法来逐个删除文件。

示例代码如下:

$context = New-AzStorageContext -StorageAccountName "AccountName" -SasToken "xxx"

# Since the file name has date, you can specify which date to be deleted.
# In this sample, we try to delete the files' name contains 201901

$pattern ="201901"

# iterate all the files, and delete    
Get-AzStorageFile -ShareName "testfolder" -Path "t1/t1sub" -Context $context | Get-AzStorageFile | where {($_.GetType().Name
 -eq "CloudFile") -and ($_.Name -like "*$pattern*")} | Remove-AzStorageFile

删除之前:

enter image description here

删除后(所有名称包含“ 201901”的文件均被删除):

enter image description here