बैच स्क्रिप्ट - टिप्पणियाँ

जो स्क्रिप्ट बनती हैं, उनके लिए टिप्पणियों या प्रलेखन को जोड़ना हमेशा एक अच्छा अभ्यास होता है। स्क्रिप्ट के रखरखाव के लिए यह आवश्यक है कि स्क्रिप्ट वास्तव में क्या करती है।

उदाहरण के लिए, निम्नलिखित कोड पर विचार करें जिसमें टिप्पणियों का कोई रूप नहीं है। यदि कोई भी औसत व्यक्ति जिसने निम्नलिखित स्क्रिप्ट का विकास नहीं किया है, वह स्क्रिप्ट को समझने की कोशिश करता है, तो उस व्यक्ति को यह समझने में बहुत समय लगेगा कि स्क्रिप्ट वास्तव में क्या करती है।

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

अब आप देख सकते हैं कि कोड उन उपयोगकर्ताओं के लिए अधिक समझ में आ गया है जिन्होंने कोड विकसित नहीं किया है और इसलिए अधिक रखरखाव योग्य है।