已知三个文本:
_learned.txt 储存已学习的单词
_to_check.txt 储存用于对比的单词
_to_learn.txt 储存第二个文本中有而第一个文本中没有的单词
方法一:用findstr语句。
findstr /beivg:_learned.txt _to_check.txt>_to_learn.txt
结果:
① 效率很高
② 但是最后一行出现了多余的一行字,内容为:%i
方法二:用for语句
for /f %%i in (_to_check.txt) do (
findstr /ix "%%i" _learned.txt >nul
if ERRORLEVEL 1 echo %%i>>_to_learn.txt
)
结果:
① 效率很低
② 内容为off或on的行未被查出
===============
请问:
① 为什么第一种方法效率很高?为什么第二种方法效率很低?
② 为什么第一种方法会出现多余的%i?如何去掉?
③ 为什么第二种方法会查不出off和on?
[
Last edited by Karman on 2008-8-16 at 07:17 PM ]