[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
返回列表 发帖
感谢楼上几位
原来set /a 的赋值效率竟没有直接set高。
测试文件8000个,我顶楼第一个代码17S,第二个21S,第一个set /a 改为set 15S
JM的代码为12S,neorobin的代码有了很大的提速,将近5S
最快的是GUN兄的,但似乎只求出的文件数,并没考虑一个区域存在两个文件或多个
搜索了gawk,发现GUN竟是原创作者,先敬仰一下。
但是未曾发现gawk的帮助内容,不知GUN兄可否再帮忙一下。

TOP

在 6 楼代码的基础上改了下, 加了一个 ECHO.>>tmp 使 'findstr /n /v "Y$" tmp' 可以有结果
  1. @echo off
  2. set t=%time%
  3. for /f "tokens=2 delims=_." %%i in ('dir /b abc\*.txt') do set ID_%%i=Y
  4. set ID_>tmp
  5. ECHO.>>tmp
  6. for /f "delims=:" %%i in ('findstr /n /v "Y$" tmp') do set /a sum=%%i-1 & set sum
  7. echo %t%
  8. echo %time%
  9. pause
复制代码
2

评分人数

    • namejm: 哈哈,怎么没想到钻findstr的这个空子呢?PB + 2
    • zhouyongjun: 谢谢PB + 10

TOP

  通过反复测试,发现顶楼代码速度的瓶颈在于频繁的 set /a 运算,如果换成 set 的赋值语句而不是set的数值运算语句,速度将大为提升。

  以下代码应当可以提高一点速度,但是会带来两个副作用:1、CPU占用飙升,将会达到100%;2、使用了临时文件:
  1. @echo off
  2. for /f "tokens=2 delims=_." %%i in ('dir /b abc\*.txt') do (
  3.     set ID_%%i=0
  4. )
  5. set ID_>tmp
  6. for /f "delims=:" %%i in ('findstr /n . tmp') do set num=%%i
  7. echo %num%
  8. echo %t%
  9. echo %time%
  10. pause
复制代码
  由于通过重定向符号>把内容倒入文本中后,会在最后一行形成仅含回车符号的空行,无法通过 findstr /n  /v "$" tmp 语句来快速获取最后一行的行号,只能逐行编号,通过set语句把最后一行的行号赋予num,使得效率大为减慢。
1

评分人数

尺有所短寸有所长,学好批处理没商量;
考虑问题复杂化,解决问题简洁化。

心在天山,身老沧州。

TOP

  1. dir /b *_*.txt | gawk -F"[_.]" "{a[$2]++}END{for(i in a)print i,a[i]}"
复制代码
1

评分人数

TOP

回复 3楼 的帖子

第三方也行,因为是工作需要,不要考虑太多可移植性,速度第一位

TOP

sed不熟,或者可以快速求出...

TOP

BAT还有比DIR 更快的遍历方式吗?
而且不管怎么遍历,都要FOR一次..
既然如此,速度要提高就很难了

TOP

返回列表