2

我正在修改一些我发现以递归方式从文件中获取元数据的 powershell 代码,但是我无法访问文件夹中的文件夹。我从\share 下直接列出的文件夹中获取元数据,而不是那里的文件夹和文件。如何将此代码修改为文件夹中文件的元数据?

另外,我正在尝试将元数据导出到 CSV,但我只得到一个空文件。

编辑:我正在尝试从 .pst 文件中获取数据。我还找到了以下行,想知道是否可以以某种方式添加它:

目录 \myserver\share -Recurse -包括 *.pst | 选择全名

($folder = "\\myserver\share") #end param
function funLine($strIN) 
{
$strLine = "=" * $strIn.length
$hash | Export-Csv c:\pstdetails.csv -NoClobber -NoTypeInformation
# Write-Host -ForegroundColor Yellow "`n$strIN"
# Write-Host -ForegroundColor Cyan $strLine
} #end funline
function funMetaData()
{ 
foreach($sFolder in $folder)
 {
  $a = 0
  $objShell = New-Object -ComObject Shell.Application
  $objFolder = $objShell.namespace($sFolder)
  foreach ($strFileName in $objFolder.items())
  { FunLine( "$($strFileName.name)")
     for ($a ; $a  -le 266; $a++)
      { 
       if($objFolder.getDetailsOf($strFileName, $a))
        {
         $hash += @{ `
              $($objFolder.getDetailsOf($objFolder.items, $a))  =`
              $($objFolder.getDetailsOf($strFileName, $a)) 
         } #end hash
         $hash
         $hash.clear()
          } #end if
      } #end for 
    $a=0
   } #end foreach
 } #end foreach
} #end funMetadata 
4

1 回答 1

0

高高在低的寻找之后,答案一直摆在我的面前。(我之前在这里搜索过!)在这里找到了答案:Recursive file search using PowerShell

我将它修改为我需要的列,所以这是我使用的代码:

Get-ChildItem -Path \\Server\Folder -Filter *.pst -Recurse | Select-Object Directory, Name, Length, CreationTime, LastAccessTime, LastWriteTime | Export-Csv "c:\emails1.csv"
于 2012-10-23T14:52:19.187 回答