- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我可以计算一个文件夹和子文件夹中的所有文件,不计算文件夹本身。
(gci -Path *Fill_in_path_here* -Recurse -File | where Name -like "*STB*").Count
STB
的所有文件。
最佳答案
基于的Theo's helpful answer直接使用.NET的([System.IO.Directory]::EnumerateFiles()
)是最快的选择(在我的测试中; YMMV-请参见下面的基准代码[1])。
它在 .NET Framework(FullCLR)中的限制上-Windows PowerShell 生成于其上-是:
EnumerationOptions
选项提供了围绕限制的
方式,请参见this answer。[System.IO.DirectoryInfo]
类型执行枚举,与Get-ChildItem
相似,该枚举返回丰富的对象而不是仅是路径字符串,从而为通用处理提供了很多资源;例如,获取所有文件大小的数组(属性.Length
,隐式应用于每个文件对象):([System.IO.DirectoryInfo] $somePath).EnumerateFiles('*STB*', 'AllDirectories').Length
Get-ChildItem
与 -Filter
参数一起使用。(Get-ChildItem -LiteralPath $somePath -Filter *STB* -Recurse -File).Count
-Force
以包括它们。 -ErrorAction SilentlyContinue
或-ErrorAction Ignore
; SilentlyContinue
的优点在于,您以后可以检查$Error
集合以确定发生的特定错误,以确保这些错误确实仅源于权限问题。$env:USERPROFILE\Cookies
)的情况。 Get-ChildItem -Recurse
始终遵循符号链接(symbolic link)/结点的目录。更明智的是,PowerShell Core默认情况下不提供,并通过-FollowSymlink
提供选择加入。 [System.IO.DirectoryInfo]
的解决方案一样,Get-ChildItem
输出丰富的对象( [System.IO.FileInfo]
/ [System.IO.DirectoryInfo]
),这些对象描述每个枚举的文件系统项,从而实现了通用处理。 -Path
(隐含的第一个位置参数)和-Include
(如TobyU's answer一样),但只是提供支持的-Filter
由于在源(文件系统驱动程序)处进行了过滤,因此速度显着提高,因此PowerShell仅接收已过滤的结果;相反,对于,-Path
/ -Include
必须首先枚举所有内容,然后在之前与通配符模式匹配。[2]-Filter
使用:*[0-9]
),并且具有遗留的怪癖-请参见this answer。 -Include
支持多个(作为数组)。 -Filter
处理通配符的方式与cmd.exe
的dir
相同。cmd.exe
的dir
命令修改MC ND's helpful answer,以在PowerShell中使用,从而简化了事情:(cmd /c dir /s /b /a-d "$somePath/*STB*").Count
.Count
(或.Length
)属性查询其元素计数。Get-ChildItem -Filter
,具体取决于过滤方案;还要注意dir /s
只能返回路径字符串,而Get-ChildItem
返回可以查询其属性的丰富对象。dir
使用:/a-d
排除目录,即仅报告文件,但还包括隐藏文件,dir
默认情况下不执行。 dir /s
在递归枚举过程中也始终会进入隐藏目录; /a
(基于属性)过滤器仅应用于枚举的叶项(在这种情况下仅应用于文件)。 dir /s
始终遵循与其他目录的符号链接(symbolic link)/连接(假设它具有必要的权限-请参阅下一点)。 dir /s
会静默忽略目录或目录的符号链接(symbolic link)/联结-尽管在上述隐藏系统联结的特定情况下这很有用(您可以使用cmd /c dir C:\ /s /ashl
找到它们)您会错过您想枚举的目录的内容,但不能真正缺少权限,因为dir /s
不会表明此类内容甚至可能存在(如果您直接针对无法访问的目录,则会产生误导性File Not Found
错误消息,并且退出代码设置为1
)。 c:\windows\winsxs
;也就是说,很容易调整测试以比较过滤性能。 cmd.exe
的子进程来调用dir /s
会引入一些开销,尽管(a)开销应该相对较低,并且(b)较大的一点是保持在与cmd.exe
相比,PowerShell Realm 具有超强的功能,因此非常值得。 Time-Command
函数,可以从this Gist下载该函数,默认情况下平均运行10次。 # Warm up the filesystem cache for the target dir.,
# both from PowerShell and cmd.exe, to be safe.
gci 'c:\windows\winsxs' -rec >$null; cmd /c dir /s 'c:\windows\winsxs' >$null
Time-Command `
{ @([System.IO.Directory]::EnumerateFiles('c:\windows\winsxs', '*', 'AllDirectories')).Count },
{ (Get-ChildItem -Force -Recurse -File 'c:\windows\winsxs').Count },
{ (cmd /c dir /s /b /a-d 'c:\windows\winsxs').Count },
{ cmd /c 'dir /s /b /a-d c:\windows\winsxs | find /c /v """"' }
Factor
列以显示相对性能):Command Secs (10-run avg.) TimeSpan Factor
------- ------------------ -------- ------
@([System.IO.Directory]::EnumerateFiles('c:\windows\winsxs', '*', 'AllDirectories')).Count 11.016 00:00:11.0158660 1.00
(cmd /c dir /s /b /a-d 'c:\windows\winsxs').Count 15.128 00:00:15.1277635 1.37
cmd /c 'dir /s /b /a-d c:\windows\winsxs | find /c /v """"' 16.334 00:00:16.3343607 1.48
(Get-ChildItem -Force -Recurse -File 'c:\windows\winsxs').Count 24.525 00:00:24.5254979 2.23
[System.IO.Directory]::EnumerateFiles()
和Get-ChildItem
解决方案都明显更快,它在.NET Core之上运行(从PowerShell Core 6.2.0-preview.4,.NET Core 2.1开始):Command Secs (10-run avg.) TimeSpan Factor
------- ------------------ -------- ------
@([System.IO.Directory]::EnumerateFiles('c:\windows\winsxs', '*', 'AllDirectories')).Count 5.094 00:00:05.0940364 1.00
(cmd /c dir /s /b /a-d 'c:\windows\winsxs').Count 12.961 00:00:12.9613440 2.54
cmd /c 'dir /s /b /a-d c:\windows\winsxs | find /c /v """"' 14.999 00:00:14.9992965 2.94
(Get-ChildItem -Force -Recurse -File 'c:\windows\winsxs').Count 16.736 00:00:16.7357536 3.29
[System.IO.Directory]::EnumerateFiles()
无疑比Get-ChildItem
解决方案要快。在我的测试中(请参阅上面的“性能比较:”部分),[System.IO.Directory]::EnumerateFiles()
也击败了cmd /c dir /s
,在Windows PowerShell中稍胜一筹,在PowerShell Core中显然如此,但在others report different findings之下。就是说,寻找整体最快的解决方案不是唯一的考虑因素,尤其是如果需要的不仅仅是计数文件,并且枚举必须可靠的话。该答案讨论了各种解决方案的权衡。-Path
和-Include
实际上比使用未过滤的Get-ChildItem
慢,而使用带有... | Where-Object Name -like *STB*
的附加管道段要慢,如OP中所示,请参见this GitHub issue。
关于performance - 有效计数目录和子文件夹中具有特定名称的文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54215968/
我在使用NetBeans 6.8时遇到以下问题。我通过项目属性->库->编译选项卡->添加JAR /文件夹添加带有jar的文件夹。在下一个窗口中,我选择文件夹,然后选择“复制到库文件夹”。但是,我仍然
我的网站有一个域别名。我想知道如何将 domainA.ext 的请求重定向到 https://domainA.ext/folderA和对 domainB.ext 的请求到 http://domainB
我应该在 Eclipse 中构建的 Android 项目中创建自己的自定义菜单文件夹吗?例如,我想创建一种出现在所有 Activity 中的标题。我知道菜单应该在 res/menu 文件夹中的 XML
我正在使用 VS2008 和 .net 3.5。我在我的解决方案中创建了一个类库(Myproject.Controllers)。在这个类下,我添加了一个 Controllers 文件夹。在文件夹中我添
我有一个包含生成后步骤的 Visual Studio 2012 扩展项目,我想在其中将 .dll 和 .AddIn 文件复制到当前用户的 Visual Studio 2012 AddIns 文件夹中。
我在专有的 linux 发行版中有一些自动下载。 他们去临时暂存盘。我想在它们完成后将它们 move 到主 RAID 阵列。我能看到的最好方法是检查磁盘上的文件夹,看看内容是否在最后一分钟发生了变化。
我目前正在使用 SVN 对我的软件项目进行版本控制。在一个正在进行的项目中,我有主干,用于客户的共同功能和规范以及分支,用于客户特定的。 有没有办法在每次执行此类操作时标记一些不应合并到分支中的文
这个问题在这里已经有了答案: How to exclude a directory in find . command (45 个回答) 8 年前关闭。 如何删除文件夹中的所有内容并排除特定文件夹和文
如何在特定目录中创建具有当前日期和时间的文件夹或文件? DateTimeFormatter f = DateTimeFormatter.ofPattern("uuuuMMdd HHmmss") ; L
有没有办法在系统文件资源管理器的左侧“文件夹”栏中打开文件或文件夹?如果没有这个,我必须打开文件资源管理器并一直导航到该文件夹所在的位置才能操作文件,这确实很不方便。对于大多数带有这样导航栏的工具
预期:我使用 go get 安装包,它在 src 文件夹中创建了所有必要的文件夹,但它们只出现在 pkg/mod 文件夹中,我不能使用它们。 现实:它说它正在下载,完成,然后什么都没有。 一切都在 W
说 foo.zip包含: a b c |- c1.exe |- c2.dll |- c3.dll 哪里a, b, c是文件夹。 如果我 Expand-Archive .\foo.zip -Destin
不久前我正在删除 var 文件夹中 Magento 的缓存。我可能是错的,但我认为我犯了一个错误,而不是删除 var/cache 中的所有内容,而是意外删除了 var 中的所有内容。 Magento
我在 svn 存储库的单独文件夹中有一些代码项目。 现在我在删除文件时遇到一些问题:大多数时候一切顺利,但有时当我从磁盘删除文件或文件夹时, checkin 过程会出现各种错误。 所以我想知道:在sv
有没有什么方法可以用很少的R命令行自动删除所有文件或文件夹?我知道 unlink() 或 file.remove() 函数,但对于这些函数,您需要定义一个字符向量,其中包含您想要的文件的所有名称删除。
用于在文件夹中查找不符合Get-Childitem的LastWriteTime过滤器日期范围标准的文件的powershell命令是什么? 因此,请检查目录中是否包含不包含在01/10/2012(十月1
我正在为我工作的公司内部使用的应用程序之一编写 NSIS 安装程序,安装过程工作正常,所有 REG 键都已创建,文件夹和服务也没有问题,该应用程序使用。出于某种我无法理解的原因,卸载过程不起作用。
我有一个 Excel 文件,并且在同一文件夹中还有一个包含我想要包含的 CSV 文件的文件夹。使用“来自文件夹”查询,第一步将给出以下查询: = Folder.Files("D:\OneDrive\D
我在docker中玩ScyllaDB。为了使ScyllaDB在docker生产设置中最有效地运行,它需要一个XFS格式的磁盘。 您知道如何在Linux和MacO中创建XFS容器卷,磁盘文件吗? 谢谢
我应该编写一个函数,其中包含之前每次与该数字相乘的乘积 基本上是这样的: > productFromLeftToRight [2,3,4,5] [120,60,20,5] 我应该使用高阶函数,例如折叠
我是一名优秀的程序员,十分优秀!