查找偶數(shù)行內(nèi)容的批處理
更新時(shí)間:2009年05月11日 12:48:46 作者:
查找偶數(shù)行內(nèi)容,大家可以看下思路。
復(fù)制代碼 代碼如下:
@echo off
:: 查找偶數(shù)行內(nèi)容
::
set n=0
for /f "delims=" %%i in (test.txt) do set /a n+=1
for /l %%i in (1,2,%n%) do (
findstr /n "." test.txt|findstr /r "^%%i:">>tmp.txt
)
for /f "tokens=1* delims=:" %%i in (tmp.txt) do echo %%j>>end.txt
del tmp.txt
start end.txt
goto :eof
另一種方案
:: 不產(chǎn)生臨時(shí)文件,并且速度要快得多
:: findstr中如果用.*,則在空行的位置會(huì)顯示"ECHO 處于關(guān)閉狀態(tài)。";
:: 如果用.,則不會(huì)打印空行
:: code by jm CMD@XP 2006-7-29
@echo off
cd.>result.txt
setlocal enabledelayedexpansion
for /f "tokens=1* delims=:" %%i in ('findstr /n "." test.txt') do (
set num=%%i
call :mod
if !mod! equ 0 echo %%j>>result.txt
)
start result.txt
goto :eof
:mod
set /a mod=%num%%%2
goto :eof
把上一段代碼稍加改造,就可以去掉文本中的空行
@echo off
cd.>tmp.txt
for /f "tokens=1* delims=:" %%i in ('findstr /n "." test.txt') do (echo %%j>>tmp.txt)
cd.>result.txt
:: 當(dāng)文本中的空行是其他未知代碼時(shí)(從網(wǎng)頁(yè)中復(fù)制過(guò)來(lái)會(huì)出現(xiàn)這種情況),
:: 會(huì)在空行處顯示"ECHO 處于關(guān)閉狀態(tài)。",以下代碼是刪除這行內(nèi)容
findstr /v "\<ECHO 處于關(guān)閉狀態(tài)。\>" tmp.txt>>result.txt
del /q tmp.txt
相關(guān)文章
用批處理網(wǎng)絡(luò)映射驅(qū)動(dòng)器后自動(dòng)修改磁盤(pán)卷標(biāo)名腳本
于一些企業(yè),內(nèi)網(wǎng)的文件服務(wù)器和傳真服務(wù)器非常常見(jiàn)。為了方便,網(wǎng)絡(luò)管理員一般會(huì)把服務(wù)器上一些的文件夾他們映射為本地磁盤(pán),方便用戶使用。2011-08-08
使用bat腳本在當(dāng)前文件夾內(nèi)創(chuàng)建文件或文件夾的快捷方式
在windows中,使用bat腳本在當(dāng)前文件夾內(nèi)創(chuàng)建文件或文件夾的快捷方式,修改REM注釋部分的值,可自定義快捷鍵的名稱(chēng)和指向目標(biāo),經(jīng)腳本之家小編測(cè)試沒(méi)問(wèn)題2024-05-05
本機(jī)每個(gè)盤(pán)都添加上卷標(biāo)的命令
此命令將為本機(jī)每個(gè)盤(pán)都添加上卷標(biāo),一般是用在新機(jī)上面。2009-05-05
通過(guò)批處理調(diào)用SQL的方法(osql)
其實(shí)通過(guò)bat調(diào)用sql就是通過(guò)sqlserver自帶的osql來(lái)支持sql語(yǔ)句,需要的朋友可以參考下2012-12-12

