बैच स्क्रिप्ट - टिप्पणियाँ
जो स्क्रिप्ट बनती हैं, उनके लिए टिप्पणियों या प्रलेखन को जोड़ना हमेशा एक अच्छा अभ्यास होता है। स्क्रिप्ट के रखरखाव के लिए यह आवश्यक है कि स्क्रिप्ट वास्तव में क्या करती है।
उदाहरण के लिए, निम्नलिखित कोड पर विचार करें जिसमें टिप्पणियों का कोई रूप नहीं है। यदि कोई भी औसत व्यक्ति जिसने निम्नलिखित स्क्रिप्ट का विकास नहीं किया है, वह स्क्रिप्ट को समझने की कोशिश करता है, तो उस व्यक्ति को यह समझने में बहुत समय लगेगा कि स्क्रिप्ट वास्तव में क्या करती है।
ECHO OFF
IF NOT "%OS%"=="Windows_NT" GOTO Syntax
ECHO.%* | FIND "?" >NUL
IF NOT ERRORLEVEL 1 GOTO Syntax
IF NOT [%2]==[] GOTO Syntax
SETLOCAL
SET WSS=
IF NOT [%1]==[] FOR /F "tokens = 1 delims = \ " %%A IN ('ECHO.%~1') DO SET WSS = %%A
FOR /F "tokens = 1 delims = \ " %%a IN ('NET VIEW ^| FIND /I "\\%WSS%"') DO FOR /F
"tokens = 1 delims = " %%A IN ('NBTSTAT -a %%a ^| FIND /I /V "%%a" ^| FIND "<03>"')
DO ECHO.%%a %%A
ENDLOCAL
GOTO:EOF
ECHO Display logged on users and their workstations.
ECHO Usage: ACTUSR [ filter ]
IF "%OS%"=="Windows_NT" ECHO Where: filter is the first part
of the computer name^(s^) to be displayed
टिप्पणियां रेम स्टेटमेंट का उपयोग करना
बैच स्क्रिप्ट में टिप्पणियां बनाने के दो तरीके हैं; रेम कमांड के माध्यम से एक है। रे बयान का अनुसरण करने वाले किसी भी पाठ को टिप्पणियों के रूप में माना जाएगा और उसे निष्पादित नहीं किया जाएगा। इस कथन का सामान्य वाक्य विन्यास निम्नलिखित है।
वाक्य - विन्यास
Rem Remarks
जहाँ 'रिमार्क्स' टिप्पणी है जिसे जोड़ने की आवश्यकता है।
निम्नलिखित उदाहरण एक आसान तरीका दिखाता है Rem कमांड का उपयोग किया जा सकता है।
उदाहरण
@echo off
Rem This program just displays Hello World
set message=Hello World
echo %message%
उत्पादन
उपरोक्त कमांड निम्न आउटपुट का उत्पादन करता है। आप देखेंगे कि रेम स्टेटमेंट वाली लाइन निष्पादित नहीं की जाएगी।
Hello World
टिप्पणियाँ :: कथन का उपयोग करना
बैच स्क्रिप्ट में टिप्पणियां बनाने का दूसरा तरीका है :: कमांड। कोई भी पाठ जो :: कथन का अनुसरण करता है, उसे टिप्पणियों के रूप में माना जाएगा और उसे निष्पादित नहीं किया जाएगा। इस कथन का सामान्य वाक्य विन्यास निम्नलिखित है।
वाक्य - विन्यास
:: Remarks
जहाँ 'रिमार्क्स' वह टिप्पणी है जिसे जोड़ने की आवश्यकता है।
निम्न उदाहरण "::" कमांड के उपयोग को दर्शाता है।
उदाहरण
@echo off
:: This program just displays Hello World
set message = Hello World
echo %message%
उत्पादन
उपरोक्त कमांड निम्न आउटपुट का उत्पादन करता है। आप देखेंगे कि :: कथन वाली लाइन निष्पादित नहीं की जाएगी।
Hello World
Note - यदि आपके पास रेम की बहुत अधिक लाइनें हैं, तो यह कोड को धीमा कर सकता है, क्योंकि अंत में बैच फ़ाइल में कोड की प्रत्येक पंक्ति को अभी भी निष्पादित करना होगा।
आइए इस विषय की शुरुआत में हमने देखी गई बड़ी स्क्रिप्ट के उदाहरण को देखें और देखें कि जब प्रलेखन इसमें जोड़ा जाता है तो यह कैसा दिखता है।
::===============================================================
:: The below example is used to find computer and logged on users
::
::===============================================================
ECHO OFF
:: Windows version check
IF NOT "%OS%"=="Windows_NT" GOTO Syntax
ECHO.%* | FIND "?" >NUL
:: Command line parameter check
IF NOT ERRORLEVEL 1 GOTO Syntax
IF NOT [%2]==[] GOTO Syntax
:: Keep variable local
SETLOCAL
:: Initialize variable
SET WSS=
:: Parse command line parameter
IF NOT [%1]==[] FOR /F "tokens = 1 delims = \ " %%A IN ('ECHO.%~1') DO SET WSS = %%A
:: Use NET VIEW and NBTSTAT to find computers and logged on users
FOR /F "tokens = 1 delims = \ " %%a IN ('NET VIEW ^| FIND /I "\\%WSS%"') DO FOR /F
"tokens = 1 delims = " %%A IN ('NBTSTAT -a %%a ^| FIND /I /V "%%a" ^| FIND
"<03>"') DO ECHO.%%a %%A
:: Done
ENDLOCAL
GOTO:EOF
:Syntax
ECHO Display logged on users and their workstations.
ECHO Usage: ACTUSR [ filter ]
IF "%OS%"=="Windows_NT" ECHO Where: filter is the first part of the
computer name^(s^) to be displayed
अब आप देख सकते हैं कि कोड उन उपयोगकर्ताओं के लिए अधिक समझ में आ गया है जिन्होंने कोड विकसित नहीं किया है और इसलिए अधिक रखरखाव योग्य है।