最近需要將重復(fù)的內(nèi)容去掉,所以就想到了使用bat或vbs實(shí)現(xiàn),沒(méi)想到網(wǎng)上已經(jīng)有人寫好了,測(cè)試也正好學(xué)習(xí)一下
使用方法:把文本拖到批處理上就行了。。。
@echo off:: Code by oicu#lsxk.org 2007/11/29rem chcp 437>nul:: 看情況使用,utf-8編碼的文件不能少了chcp命令,一般無(wú)需使用,:: 但無(wú)論是否使用都不支持utf-16的文件。:: pushd "%~dp1":: 如果不用pushd和popd,文件都要用絕對(duì)路徑不能只用文件名。if "%~1"=="" goto :EOFset outputfile=%~dpn1_output%~x1type nul>"%outputfile%"echo Waiting...for /F "tokens=1* delims=:" %%i in ('findstr /n .* "%~1"') do ( findstr /B /E /C:"%%j" "%outputfile%">nul 2>&1 || echo.%%j>>"%outputfile%")pausestart "" notepad "%outputfile%":: popdexit
【 在 oicu (Oh! I see you!) 的大作中提到: 】
: 去重復(fù)倒是行。。缺點(diǎn)就是慢和保留原有的空行了。
以下是vbs實(shí)現(xiàn)的代碼
以下是這個(gè)腳本的源代碼,復(fù)制后另存為vbs后綴的文件,雙擊即可運(yùn)行。文件要放在C盤根下的Text.TXT,請(qǐng)?zhí)貏e注意:文本中一行一條記錄,不要有空行。
Const adOpenStatic = 3Const adLockOptimistic = 3Const adCmdText = &H0001 Set objConnection = CreateObject("ADODB.Connection")Set objRecordSet = CreateObject("ADODB.Recordset")strPathToTextFile = "C:/"strFile = "Test.txt"objConnection.Open "Provider=Microsoft.Jet.OLEDB.4.0;" & _ "Data Source=" & strPathtoTextFile & ";" & _ "Extended Properties=""text;HDR=NO;FMT=Delimited"""objRecordSet.Open "Select DISTINCT * FROM " & strFile, _ objConnection, adOpenStatic, adLockOptimistic, adCmdTextDo Until objRecordSet.EOFSet objFSO = CreateObject("Scripting.FileSystemObject") set Fp=objFSO.OpenTextFile("C:/test1.txt",8,True,0) fp.WriteLine objRecordSet.Fields.Item(0).Value fp.close set objFSO = nothing objRecordSet.MoveNextLoop
新聞熱點(diǎn)
疑難解答