4
我想制作一个PowerShell脚本,它将计算目录&子目录中的所有.xml文件并列出值+路径。Powershell脚本来计算目录和子目录中的特定文件
到目前为止,我已经做了这一点:
Get-ChildItem -Path c:/test -recurse -include *.xml
这是接近我想要的东西,但没有实际的文件名,只是在文件夹路径和计数。
这就是我得到:
> Directory: C:\test\A_Sub-folder
> Mode LastWriteTime Length Name
> ---- ------------- ------ ----
> -a--- 27/11/2015 11:29 0 AA.xml
>
> Directory: C:\test
> Mode LastWriteTime Length Name
> ---- ------------- ------ ----
> -a--- 27/11/2015 11:29 0 BB.xml
> -a--- 27/11/2015 11:29 0 CC.xml
> -a--- 27/11/2015 11:29 0 DD.xml
而我试图让这个(或类似):
> Directory: C:\test\A_Sub-folder
> 1
> Directory: C:\test
> 3
的计划是运行的每个根驱动器上运行此脚本(某些驱动器有大约5K .xml文件,所以我不知道这将如何影响性能)
编辑:
这适用于子文件夹,但由于某些原因,它无法在根目录下运行(例如。 E:/)。 我想排除\ windows和\ program文件,但它不起作用。有什么方法可以排除搜索中的根目录吗?
脚本至今:
$excludedPaths = @("E:\Windows", "E\Program Files", "E:\Program Files (x86)", "E:\MSSQL", "E:\MSSQL11.MSSQLSERVER");
$pathtocount = Read-Host -Prompt 'Input path to count xml files'
Get-ChildItem -Path $pathtocount -recurse -include *.xml | Where-Object { $excludedPaths -notcontains $_.Directory } | Group-Object -Property Directory | Sort-Object count
您的问题比我的要好。 :) – Nate
@Nate不要气馁,你在回答中做出了很好的努力,但它不完全正确。继续尝试,很高兴看到新的人张贴答案! :)另外,您可以通过解决其他人的问题来学习多少。有时它会带来对问题的全新观点,并有助于解决您自己遇到的问题。 – TheMadTechnician
太棒了!正是我想要的!欢呼家伙:) – daelas