উইন্ডোজ ব্যাচ স্ক্রিপ্ট (.bat) এ পাস হওয়া আর্গুমেন্টের তালিকা পান


405

আমি বাশ-এর ​​উইন্ডোজ ব্যাচের সমকক্ষকে খুঁজে পেতে চাই যা $@স্ক্রিপ্টে পাস হওয়া সমস্ত আর্গুমেন্টের একটি তালিকা ধারণ করে।

নাকি আমাকে বিরক্ত করতে হবে shift?

উত্তর:


622

%*সমস্ত কমান্ড লাইন প্যারামিটারের (স্ক্রিপ্টের নামটি বাদ দিয়ে) ড্যানচাওয়ালারোর ঠিক আছে । আপনার এটা কাজে লাগতে পারে:

%0- ব্যাচ ফাইল কল করার জন্য ব্যবহার করা কমান্ড (হতে পারে foo, ..\foo, c:\bats\foo.bat, ইত্যাদি)
%1প্রথম কমান্ড লাইন প্যারামিটার হয়
%2দ্বিতীয় কমান্ড লাইন প্যারামিটার,
ইত্যাদি পর্যন্ত %9(এবং SHIFT9 ম পরবর্তীদের অবস্থা হয়েছিল জন্য ব্যবহার করা যেতে পারে)।

%~nx0- কলিং পদ্ধতি (কিছু-ব্যাচ.বাট) নির্বিশেষে ব্যাচের ফাইলের আসল নাম
%~dp0- ড্রাইভ এবং স্ক্রিপ্টের পথ (d: rip স্ক্রিপ্ট)
%~dpnx0- স্ক্রিপ্টের সম্পূর্ণ যোগ্য প্যাথ নাম (ডি: rip স্ক্রিপ্টস \ কিছু) -batch.bat)

Https://www.ss64.com/nt/syntax-args.html এবং https://www.robvenderwoude.com/paraters.html এ আরও তথ্যের উদাহরণ


11
দ্রষ্টব্য, যে SHIFT% * কে প্রভাবিত করে না, এভাবে SHIFT ব্যবহার করা অসম্ভব হয়ে উঠেছে [/ n] কিছুটা স্বজ্ঞাত হিসাবে যেমন n-th পরামিতি থেকে শুরু করে পুরো কমান্ড লাইনটি অ্যাক্সেস করতে পারে।
ভ্যান জোন

4
আমি অন্য কিছু আবিষ্কার করেছিলাম %~dpn0এটি ড্রাইভ এবং স্ক্রিপ্টের প্লাসটি ব্যাচ ফাইলের নাম ফিরিয়ে দেবে, তবে এক্সটেনশন নয়। .ps1একই নামের সাথে একটি ফাইল কল করে এমন ব্যাচ স্ক্রিপ্ট তৈরি করার সময় আমি এটি বিশেষভাবে দরকারী বলে মনে করি । মূলত, dড্রাইভকে pবোঝায়, পথকে nবোঝায়, ফাইলটির নাম xবোঝায় এবং এক্সটেনশনকে বোঝায়। সেই তথ্য সহ, আপনি বেশ কিছু করতে পারেন।
ড্যান অ্যাটকিনসন

কৌতূহলের বাইরে, ধরুন আমি ECHO ব্যবহার করে ফাইলের প্রিন্ট প্রিন্ট করতে চাইছি তবে এর এক্সটেনশনটি প্রতিস্থাপন করছি, কীভাবে হবে?
ম্যাথিউস রোচা

2
@ ম্যাথিউসরোচা@echo %~n0.my_ext
ম্যাট উইলকি

@ ম্যাটওয়িলকি ধন্যবাদ আপনাকে ফলস্বরূপ এটি কী মুদ্রণ করবে তা দেখার জন্য আমি ECHO ব্যবহার করে এটি আবিষ্কার করেছি।
ম্যাথিউস রোকা

149

%* স্ক্রিপ্টে পাস সমস্ত আর্গুমেন্ট ধরে মনে হচ্ছে।


কোনও ধারণা কেন এটি কিছু চরিত্রগুলি পরিচালনা করে না &? যখন আমি বেশ কয়েকটি নির্বাচিত ফাইলের কয়েকটি পথ পুনরুদ্ধার করার চেষ্টা করি (মেনুতে প্রেরণ করুন এবং "% *" যা আর্গিগুলি একটি .py এ পাস করে ব্যবহার করে) এটি & ক্যারেক্টারে তালিকাবদ্ধকরণ বন্ধ করে দেয়। সুতরাং উদাহরণস্বরূপ, যদি দ্বিতীয় ফাইলটির &নামের সাথে একটি ফাইল থাকে , তবে নামের পরে &থাকা অংশটিও বাদ দেওয়া হবে এবং অবিরত ফাইলগুলিও))
জিনস্নো

1
@ জিনস্নো দ্য &একটি বিশেষ চরিত্র যার অর্থ stop this command and start another one। একটি ফাইলের নাম থাকা দরকার যা উদ্ধৃত করা & আবশ্যক
জেসি চিশলম

65

%1... %nএবং %*তর্কগুলি ধারণ করে তবে এগুলি অ্যাক্সেস করা মুশকিল হতে পারে, কারণ সামগ্রীটির ব্যাখ্যা দেওয়া হবে।
সুতরাং সাধারণ বিবৃতি দিয়ে এই জাতীয় কিছু পরিচালনা করা অসম্ভব

myBatch.bat "&"^&

প্রতিটি লাইন ব্যর্থ হয়, যেহেতু সেমিডি.এক্সই একটি অ্যাম্পারস্যান্ডগুলি চালিত করার চেষ্টা করে (% 1 এর সামগ্রীটি হ'ল "&"&)

set var=%1
set "var=%1"
set var=%~1
set "var=%~1"

কিন্তু অস্থায়ী ফাইল সহ একটি কার্যকারিতা রয়েছে

@echo off
SETLOCAL DisableDelayedExpansion

SETLOCAL
for %%a in (1) do (
    set "prompt=$_"
    echo on
    for %%b in (1) do rem * #%1#
    @echo off
) > param.txt
ENDLOCAL

for /F "delims=" %%L in (param.txt) do (
  set "param1=%%L"
)
SETLOCAL EnableDelayedExpansion
set "param1=!param1:*#=!"
set "param1=!param1:~0,-2!"
echo %%1 is '!param1!'

কৌশলটি হ'ল একটি বিবৃতি (% 2 ..% * এর সাথেও কাজ করে) সক্ষম echo onকরার %1পরে প্রসারিত করা rem
তবে এর আউটপুট পুনর্নির্দেশ করতে সক্ষম হতে echo onআপনার দুটি ফোর-লুপ দরকার।

অতিরিক্ত অক্ষরগুলি ( * #যেমনটি /?আরইএমের জন্য সহায়তা প্রদর্শন করবে) এর মতো সামগ্রীগুলির বিরুদ্ধে নিরাপদ থাকতে ব্যবহৃত হয় ।
বা লাইনের শেষে একটি ক্যারেট একাধিক লাইন চরিত্র হিসাবে কাজ করতে পারে।

ফর / এফটি বিলম্বিত সম্প্রসারণ বন্ধ করে দিয়ে কাজ করা উচিত, অন্যথায় সামগ্রী "!" ধ্বংস করা হবে।
অতিরিক্ত অক্ষর মুছে ফেলার পরে param1এবং আপনি এটি পেয়েছেন।

এবং param1নিরাপদ উপায়ে ব্যবহার করতে, বিলম্বিত প্রসারণ সক্ষম করুন।

সম্পাদনা:% 0 এ এক মন্তব্য

%0ব্যাচ কল করার জন্য ব্যবহৃত কমান্ডটি রয়েছে, তবে কেসটি FoO.BaT
ফাংশনে কল করার পরে %0এবং এর %~0মধ্যে ফাংশনের নামও রয়েছে (বা ফাংশনটি কল করার জন্য ব্যবহৃত স্ট্রিংটি আরও ভাল ছিল)।
তবে আপনার সাথে %~f0এখনও ফাইলের নামটি স্মরণ করতে পারেন।

@echo off
echo main %0, %~0, %~f0
call :myLabel+xyz
exit /b

:MYlabel
echo func %0, %~0, %~f0
exit /b

আউটপুট

main test.bat, test.bat, C:\temp\test.bat
func :myLabel+xyz, :myLabel+xyz, C:\temp\test.bat

6
+++ 1 ওএমজি - %~f0কৌশলটি সম্পূর্ণ অপ্রত্যাশিত, দুর্দান্ত উপায়ে এবং সম্ভাব্যভাবে খুব দরকারী :-) অবাক হওয়ার কিছু নেই, অন্য মোডিফায়াররা একইভাবে কাজ করে, সর্বদা অভিভাবক ব্যাচের ফাইলে অপারেটিং থাকে, এমনকি যখন নামক সাব্রোটিনে থাকে তখনও। এটি তার নিজস্ব প্রশ্নোত্তর হিসাবে উপযুক্ত বলে মনে হচ্ছে - "যখন একটি ডাকা সাব্রোটিনে চলমান ব্যাচের নামটি কীভাবে অ্যাক্সেস করবেন?"
dbenham

যদি আমি সঠিকভাবে মনে রাখি, আপনি আর্গুমেন্ট সহ কলটি ব্যবহার করতে পারেন এবং সেগুলি% 1,% 2, ...% n তে সংরক্ষণ করা হবে ঠিক যেমন আপনি কোনও স্ক্রিপ্ট চালাবেন।
নুলানো

49

আমি খুঁজে পেয়েছি যে পরের বার যখন আপনার এই তথ্যগুলি সন্ধান করা দরকার। একটি ব্রাউজার খোলার এবং গুগল করার পরিবর্তে, আপনি কেবল call /?নিজের সেন্টিমিডিতে টাইপ করতে পারেন এবং আপনি এটি পাবেন:

...

%* in a batch script refers to all the arguments (e.g. %1 %2 %3
    %4 %5 ...)

Substitution of batch parameters (%n) has been enhanced.  You can
now use the following optional syntax:

    %~1         - expands %1 removing any surrounding quotes (")
    %~f1        - expands %1 to a fully qualified path name
    %~d1        - expands %1 to a drive letter only
    %~p1        - expands %1 to a path only
    %~n1        - expands %1 to a file name only
    %~x1        - expands %1 to a file extension only
    %~s1        - expanded path contains short names only
    %~a1        - expands %1 to file attributes
    %~t1        - expands %1 to date/time of file
    %~z1        - expands %1 to size of file
    %~$PATH:1   - searches the directories listed in the PATH
                   environment variable and expands %1 to the fully
                   qualified name of the first one found.  If the
                   environment variable name is not defined or the
                   file is not found by the search, then this
                   modifier expands to the empty string

The modifiers can be combined to get compound results:

    %~dp1       - expands %1 to a drive letter and path only
    %~nx1       - expands %1 to a file name and extension only
    %~dp$PATH:1 - searches the directories listed in the PATH
                   environment variable for %1 and expands to the
                   drive letter and path of the first one found.
    %~ftza1     - expands %1 to a DIR like output line

In the above examples %1 and PATH can be replaced by other
valid values.  The %~ syntax is terminated by a valid argument
number.  The %~ modifiers may not be used with %*

20

স্ক্রিপ্টে সমস্ত আরগগুলি উদ্ধার করার উপায়টি এখানে:

@ECHO off
ECHO The %~nx0 script args are...
for %%I IN (%*) DO ECHO %%I
pause

2
সত্যই নয়, %%Iব্যাখ্যা করা এবং আপনার স্ক্রিপ্টটি ভেঙে দিতে পারে।
বরিস ব্রডস্কি

5

আরগগুলি পেতে এবং এনভ ভার্স হিসাবে সেট করার জন্য মোটামুটি সহজ উপায়। এই উদাহরণে আমি তাদের কী এবং মান হিসাবে উল্লেখ করব।

নিম্নলিখিত কোড উদাহরণটি "args.bat" হিসাবে সংরক্ষণ করুন। তারপরে আপনি একটি কমান্ড লাইন থেকে বাচানো ফাইলটিকে কল করুন। উদাহরণস্বরূপ: arg.bat --x 90 --y 120

প্রক্রিয়াটির মধ্য দিয়ে আপনাকে পদক্ষেপ নেওয়ার জন্য কিছু ইকো কমান্ড সরবরাহ করেছি। তবে শেষ ফলাফলটি হ'ল --x এর মান 90 হবে এবং --YY এর মূল্য হবে 120 (এটি যদি আপনি উপরে বর্ণিত উদাহরণটি চালাচ্ছেন ;-))।

তারপরে আপনার কোড ব্লকটি চালানো হবে কিনা তা নির্ধারণ করতে আপনি 'যদি সংজ্ঞায়িত হন' শর্তাধীন বিবৃতিটি ব্যবহার করতে পারেন। সুতরাং রানটি বলতে দাও: "arg.bat --x হ্যালো-ওয়ার্ল্ড" আমি তখন "IF সংজ্ঞায়িত - x প্রতিধ্বনি% - x%" বিবৃতিটি ব্যবহার করতে পারি এবং ফলাফলগুলি হ্যালো-ওয়ার্ল্ড হবে। আপনি যদি ব্যাচটি চালান তবে এটি আরও বোধ করা উচিত।

@setlocal enableextensions enabledelayedexpansion
@ECHO off
ECHO.
ECHO :::::::::::::::::::::::::: arg.bat example :::::::::::::::::::::::::::::::
ECHO :: By:      User2631477, 2013-07-29                                   ::
ECHO :: Version: 1.0                                                         ::
ECHO :: Purpose: Checks the args passed to the batch.                        ::
ECHO ::                                                                      ::
ECHO :: Start by gathering all the args with the %%* in a for loop.          ::
ECHO ::                                                                      ::
ECHO :: Now we use a 'for' loop to search for our keys which are identified  ::
ECHO :: by the text '--'. The function then sets the --arg ^= to the next    ::
ECHO :: arg. "CALL:Function_GetValue" ^<search for --^> ^<each arg^>         ::
ECHO ::                                                                      ::
ECHO ::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::

ECHO.

ECHO ::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::
ECHO :: From the command line you could pass... arg.bat --x 90 --y 220       ::
ECHO ::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::
ECHO.
ECHO.Checking Args:"%*"

FOR %%a IN (%*) do (
    CALL:Function_GetValue "--","%%a" 
)

ECHO.
ECHO ::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::
ECHO :: Now lets check which args were set to variables...                   ::
ECHO ::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::
ECHO.
ECHO ::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::
ECHO :: For this we are using the CALL:Function_Show_Defined "--x,--y,--z"   ::
ECHO ::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::
ECHO.
CALL:Function_Show_Defined "--x,--y,--z"
endlocal
goto done

:Function_GetValue

REM First we use find string to locate and search for the text.
echo.%~2 | findstr /C:"%~1" 1>nul

REM Next we check the errorlevel return to see if it contains a key or a value
REM and set the appropriate action.

if not errorlevel 1 (
  SET KEY=%~2
) ELSE (
  SET VALUE=%~2
)
IF DEFINED VALUE (
    SET %KEY%=%~2
    ECHO.
    ECHO ::::::::::::::::::::::::: %~0 ::::::::::::::::::::::::::::::
    ECHO :: The KEY:'%KEY%' is now set to the VALUE:'%VALUE%'                     ::
    ECHO :::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::
    ECHO.
    ECHO %KEY%=%~2
    ECHO.
    REM It's important to clear the definitions for the key and value in order to
    REM search for the next key value set.
    SET KEY=
    SET VALUE=
)
GOTO:EOF

:Function_Show_Defined 
ECHO.
ECHO ::::::::::::::::::: %~0 ::::::::::::::::::::::::::::::::
ECHO :: Checks which args were defined i.e. %~2
ECHO :::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::
ECHO.
SET ARGS=%~1
for %%s in (%ARGS%) DO (
    ECHO.
    ECHO :::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::
    ECHO :: For the ARG: '%%s'                         
    IF DEFINED %%s (
        ECHO :: Defined as: '%%s=!%%s!'                                             
    ) else (
        ECHO :: Not Defined '%%s' and thus has no value.
    )
    ECHO :::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::
    ECHO.
)
goto:EOF

:done

এটি খুব দরকারী!
robe007

3

এখানে চিত্র বর্ণনা লিখুন

সমস্ত আর্গুমেন্ট পেতে এবং খাঁটি ব্যাচে লুপিং ব্যবহার করার জন্য:

ওবস: ব্যবহার ছাড়াই:?*&<>


@echo off && setlocal EnableDelayedExpansion

for %%Z in (%*)do set "_arg_=%%Z" && set/a "_cnt+=1+0" && call set "_arg_[!_cnt!]=!_arg_!")

:: write/test these arguments/parameters ::
for /l %%l in (1 1 !_cnt!)do echo/ The argument n:%%l is: !_arg_[%%l]!

goto :eof 

আপনার কোডটি আর্গুমেন্ট নম্বরটি যেখানে এটি প্রয়োজন সেখানে কিছু করতে প্রস্তুত, যেমন ...

@echo off && setlocal EnableDelayedExpansion

for %%Z in (%*)do set "_arg_=%%Z" && set/a "_cnt+=1+0" && call set "_arg_[!_cnt!]=!_arg_!"

echo= !_arg_[1]! !_arg_[2]! !_arg_[2]!> log.txt

2

নিম্নলিখিত কোডটি একটি অ্যারে (' params') সিমুলেট করে - স্ক্রিপ্ট দ্বারা প্রাপ্ত প্যারামিটারগুলি নেয় এবং এগুলি ভেরিয়েবলগুলিতে সঞ্চয় করে params_1.. params_n, যেখানে n= params_0= অ্যারের উপাদানগুলির সংখ্যা:

@echo off

rem Storing the program parameters into the array 'params':
rem Delayed expansion is left disabled in order not to interpret "!" in program parameters' values;
rem however, if a parameter is not quoted, special characters in it (like "^", "&", "|") get interpreted at program launch
set /a count=0
:repeat
    set /a count+=1
    set "params_%count%=%~1"
    shift
    if defined params_%count% (
        goto :repeat
    ) else (
        set /a count-=1
    )    
set /a params_0=count

rem Printing the program parameters stored in the array 'params':
rem After the variables params_1 .. params_n are set with the program parameters' values, delayed expansion can
rem be enabled and "!" are not interpreted in the variables params_1 .. params_n values
setlocal enabledelayedexpansion
    for /l %%i in (1,1,!params_0!) do (
        echo params_%%i: "!params_%%i!"
    )
endlocal

pause
goto :eof

1

আপনার যদি কোটগুলিতে পরামিতি থাকে যা ফাঁকা স্থান রয়েছে, %*সঠিকভাবে কাজ করবে না। আমি সবচেয়ে ভাল সমাধানটি পেয়েছি যে একটি লুপ রয়েছে যা সমস্ত আর্গুমেন্টে যোগ দেয়: https://serverfault.com/a/22541

set args=%1
shift
:start
if [%1] == [] goto done
set args=%args% %1
shift
goto start

:done
(use %args% here)

1

Forআরগের তালিকা পেতে আপনি কমড ব্যবহার করতে পারেন ।

সহায়তা: For /? সহায়তা:Setlocal /?

এখানে আমার উপায় =

@echo off
::For Run Use This = cmd /c ""Args.cmd" Hello USER Scientist etc"
setlocal EnableDelayedExpansion
set /a Count=0
for %%I IN (%*) DO (
 Echo Arg_!Count! = %%I
 set /a Count+=1 
)
Echo Count Of Args = !Count!
Endlocal

শিফ্ট কমান্ডের দরকার নেই।


0
@ কেচো অফ
: শুরু

:: আপনার কোড এখানে .োকান
প্রতিধ্বনিত। %% 1 এখন:% ~ 1
:: এখানে আপনার কোড প্রবেশ করান শেষ

যদি "% ~ 2" NEQ "" (
    পরিবর্তন
    গেটো: শুরু
)

0

উপরের তথ্য প্রচুর আমাকে আরও গবেষণার দিকে নিয়ে গিয়েছিল এবং শেষ পর্যন্ত আমার উত্তর তাই আমি আশা করি যে এটি অন্য কাউকে সহায়তা করে আমি যা করেছিলাম তা অবদান রাখতে চেয়েছিলাম:

  • আমি একটি ব্যাচ ফাইলে বিবিধ সংখ্যক ভেরিয়েবল পাস করতে চেয়েছিলাম যাতে সেগুলি ফাইলের মধ্যে প্রক্রিয়া করা যায়।

  • আমি উদ্ধৃতি ব্যবহার করে ব্যাচ ফাইলে তাদের পাস করার সাথে ঠিক ছিলাম

  • আমি তাদের নীচের অনুরূপ প্রক্রিয়া করতে চাই - তবে ম্যানুয়ালি লেখার পরিবর্তে একটি লুপ ব্যবহার করুন:

সুতরাং আমি এটি কার্যকর করতে চেয়েছিলাম:

prog_ZipDeleteFiles.bat "_appPath=C:\Services\Logs\PCAP" "_appFile=PCAP*.?"

এবং লুপের যাদু দ্বারা ব্যাচ ফাইলের মধ্যে এটি করুন:

set "_appPath=C:\Services\Logs\PCAP"
set "_appFile=PCAP*.?"

আমার যে সমস্যাটি ছিল তা হ'ল লুপের জন্য আমার ব্যবহারের সমস্ত প্রচেষ্টা কাজ করছে না। নীচের উদাহরণ:

for /f "tokens* delims= " in %%A (%*) DO (
   set %%A
)

শুধু করতে হবে:

set "_appPath=C:\Services\Logs\PCAP"

এবং না:

set "_appPath=C:\Services\Logs\PCAP"
set "_appFile=PCAP*.?"

এমনকি সেট করার পরেও

SETLOCAL EnableDelayedExpansion

কারণটি ছিল লুপটির প্রথম পুনরাবৃত্তির জন্য লুপটি পুরো লাইনটি পড়ে এবং আমার দ্বিতীয় প্যারামিটারটি %% B এ নিয়োগ করে। যেহেতু% * সমস্ত আর্গুমেন্টকে উপস্থাপন করে, প্রক্রিয়া করার জন্য কেবলমাত্র একটি লাইন রয়েছে - লুপের জন্য কেবলমাত্র একটি পাসটি ঘটে। এটি নকশার দ্বারা এটি সক্রিয় হয়, এবং আমার যুক্তিটি ভুল ছিল।

সুতরাং আমি লুপের জন্য একটি ব্যবহার করার চেষ্টা বন্ধ করে দিয়েছি এবং শিফট, এবং একটি গেটো স্টেটমেন্ট ব্যবহার করে যা করার চেষ্টা করছি তা সরল করে দিয়েছি। এটি একটি হ্যাক কিছুটা স্বীকার করেছেন তবে এটি আমার প্রয়োজনের সাথে আরও উপযুক্ত। আমি সমস্ত আর্গুমেন্টের মধ্যে লুপ করতে পারি এবং তারপরে আমি সমস্তগুলি প্রক্রিয়া করার পরে লুপ থেকে বাদ দিতে একটি if স্টেটমেন্ট ব্যবহার করতে পারি।

আমি যা অর্জন করার চেষ্টা করেছিলাম তার জন্য বিজয়ী বিবৃতি:

echo on
:processArguments
:: Process all arguments in the order received
if defined %1 then (
    set %1
    shift
    goto:processArguments
) ELSE (
    echo off 
)

আপডেট - পরিবর্তে আমাকে নীচে পরিবর্তন করতে হয়েছিল,% 1 রেফারেন্স দেওয়ার চেষ্টা করার সময় এবং এই পদ্ধতিতে শিফ্ট ব্যবহার করার সময় আমি সমস্ত পরিবেশের ভেরিয়েবলগুলি প্রকাশ করেছিলাম:

echo on
shift
:processArguments
:: Process all arguments in the order received
if defined %0 then (
    set %0
    shift
    goto:processArguments
) ELSE (
    echo off 
)

আমি ভুল, আরও কিছু চেকিং করেছি এবং তৃতীয় পুনরাবৃত্তির পরে আমার শিফট কমান্ড পরিবেশের ভেরিয়েবলগুলির সমস্ত প্রকাশ করে যা উপরের অংশগুলিকে ভেঙে দেয়। এর আশেপাশে কোনও উপায় আছে কিনা তা আমি এখনও সন্ধান করছি।
জন আহেরন

একটি পরিবর্তন করতে হয়েছিল,% 1 ব্যবহারের পরিবর্তে, একবার আমাকে প্রথমে শিফট করতে হয়েছিল এবং% 0 ব্যবহার করতে হয়েছিল অথবা অন্যথায় আমি একটি অদ্ভুত সমস্যায় পড়েছিলাম যেখানে অবশেষে% 1 এ সমস্ত বর্তমান পরিবেশের পরিবর্তনশীল রয়েছে।
জন আহেরন

0

কখনও কখনও আমাকে বেশ কয়েকটি কমান্ড লাইন প্যারামিটারগুলি বের করতে হবে তবে সেগুলি সবই নয় এবং প্রথমটি থেকেও নয়। আসুন নিম্নলিখিত কলটি ধরে নিই:

Test.bat uno dos tres cuatro cinco seis siete

অবশ্যই, ".bat" এক্সটেনশানটি কমপক্ষে আপনার একই ফোল্ডারে টেস্ট.এক্সপি থাকা দরকার। আমরা যা চাই তা হ'ল আউটপুট "ট্রেস কুয়েট্রো সিনকো" (এক লাইন বা তিনটি নয়) get লক্ষ্যটি হ'ল কেবল আমার তিনটি পরামিতি প্রয়োজন এবং তৃতীয়টি দিয়ে শুরু করা উচিত। একটি সাধারণ উদাহরণ পেতে প্রত্যেকের ক্রিয়াটি কেবল "প্রতিধ্বনি" হয় তবে আপনি নির্বাচিত পরামিতিগুলির উপরে আরও কিছু জটিল ক্রিয়াতে ভাবতে পারেন।

আমি কয়েকটি উদাহরণ তৈরি করেছি, (বিকল্পগুলি) যাতে আপনি দেখতে পারেন যে কোনটি আপনার জন্য ভাল। দুর্ভাগ্যক্রমে, "" %% i in (% 3, 1,% 5) "এর মতো পরিসরের উপরে লুপের উপর ভিত্তি করে একটি সুন্দর (বা আমি এটি সম্পর্কে জানি না) উপায় নেই।

@echo off 
setlocal EnableDelayedExpansion

echo Option 1: one by one (same line)
echo %3, %4, %5
echo.

echo Option 2: Loop For one by one
for %%a in (%3, %4, %5) do echo %%a
echo.

echo Option 3: Loop For with check of limits
set i=0
for %%a in (%*) do (
    set /A i=i+1
    If !i! GTR 2 if !i! LSS 6 echo %%a
)
echo.

echo Option 4: Loop For with auxiliary list
for /l %%i in (3,1,5) do  (
    set a=%%i
    set b=echo %%
    set b=!b!!a!
    call !b!
)
echo.

echo Option 5: Assigning to an array of elements previously
set e[0]=%0
set i=0 
for %%a in (%*) do (
    set /A i=i+1
    set e[!i!]=%%a
)
for  /l %%i in (3,1,5) do (
    echo !e[%%i]!
)
echo.

echo Option 6: using shift and goto loop. It doesn't work with for loop
set i=2
:loop6
    set /A i=i+1
    echo %3
    shift
    If %i% LSS 5 goto :loop6

সম্ভবত আপনি আরও বিকল্প খুঁজে পেতে পারেন বা কয়েকটি একত্রিত করতে পারেন। তাদের উপভোগ.


-1

উইন্ডোজ সংস্করণ (যদিও সোকাট প্রয়োজন)

C:\Program Files (x86)\Git\bin>type gitproxy.cmd
socat STDIO PROXY:proxy.mycompany.de:%1:%2,proxyport=3128

এটি সেট আপ:

C:\Users\exhau\AppData\Roaming\npm>git config --global core.gitproxy gitproxy.cmd
আমাদের সাইট ব্যবহার করে, আপনি স্বীকার করেছেন যে আপনি আমাদের কুকি নীতি এবং গোপনীয়তা নীতিটি পড়েছেন এবং বুঝতে পেরেছেন ।
Licensed under cc by-sa 3.0 with attribution required.