需要扫描所有域计算机上的.pst文件

时间:2017-05-09 19:30:44

标签: powershell group-policy

我是全新的powershell sctipting。我有一些使用Exchange PowerShell的经验,但这一直是针对非常具体的项目,如调整日历权限等。没有什么可以强大的 目前我正在开发一个powershell脚本,通过组策略推出,该策略将在每台域PC上运行搜索。我一直在寻求同事的帮助,但他现在无法获得帮助,有时候我很难跟踪他。我是这个网站,它的用户可能能够帮助我。我想要做的事情(我相信我很接近)正在为域中的每台计算机提取驱动器列表。一旦我拉出该列表,就将其输入变量,然后对该变量进行搜索,查找以.pst结尾的任何文件。一旦搜索完成,如果搜索结果,则应使用FUllname" path"创建文件。每个文件和计算机名称应用于命名文件。如果搜索没有结果,则文件将为空,但文件名仍应以计算机命名。我相信我已经得到了一切正确,除了我不知道如何根据计算机名称命名文件。感谢您的时间和帮助。
到目前为止,这是我的代码:

$drives=Get-WmiObject -query "SELECT * from win32_logicaldisk where 
DriveType = '3'" | select deviceid
    foreach ($drive in $drives){
        $pstfound=Get-ChildItem $drive.deviceid *.pst -recurse | select 
        fullname
        $pst+=$pstfound
        }
        IF ($pst -eq $null) {
        $pst | Out-File \\"Servername"\Searchresults\Null
        } Else {
        $pst | Out-File \\"Servername"\Searchresults\HasItems
        }

1 个答案:

答案 0 :(得分:0)

谢谢。我最初并没有计划使用UNC路径,但无论如何都要改变它,我认为这样可以让以后更容易完成。我还想出了在运行它的计算机后命名生成的文件的问题。我只是设置一个变量$ hostname = hostname,然后将文件设置为\ $ hostname.csv