% PATH %에 디렉터리가 있는지 확인하는 방법은 무엇입니까?
디렉토리가 이미 PATH 환경 변수에 있는지 어떻게 확인합니까? 시작합니다. 하지만 아래 코드로 할 수 있었던 것은 % PATH %의 첫 번째 디렉토리를 에코하는 것뿐입니다. 이것은 FOR 루프이기 때문에 % PATH %의 모든 디렉터리를 열거 할 것이라고 생각할 수 있지만 첫 번째 디렉터리 만 가져옵니다.
이 작업을 수행하는 더 좋은 방법이 있습니까? % PATH % 변수에서 작동하는 find 또는 findstr과 같은 것이 있습니까? % PATH %의 디렉터리 목록에 디렉터리가 있는지 확인하여 이미있을 수있는 항목을 추가하지 않도록하고 싶습니다.
FOR /F "delims=;" %%P IN ("%PATH%") DO (
@ECHO %%~P
)
먼저이 문제를 완벽하게 해결하기 어렵게 만드는 몇 가지 문제를 지적하겠습니다. 그런 다음 내가 생각 해낼 수 있었던 가장 방탄 솔루션을 제시하겠습니다.
이 논의에서는 소문자 경로를 사용하여 파일 시스템의 단일 폴더 경로를 나타내고 대문자 PATH를 사용하여 PATH 환경 변수를 나타냅니다.
실용적인 관점에서, 대부분의 사람들은 PATH에 주어진 경로의 정확한 문자열 일치가 포함되어 있는지 여부가 아니라 PATH에 주어진 경로와 논리적으로 동등한 항목이 포함되어 있는지 알고 싶어합니다. 다음과 같은 이유로 문제가 될 수 있습니다.
\
경로에서 후행 은 선택 사항입니다.
대부분의 경로 는 후행 이있는 경우 와없는 경우 모두 동일하게 잘 작동합니다\
. 경로는 논리적으로 어느 쪽이든 동일한 위치를 가리 킵니다. PATH는 종종 후행이 있거나없는 경로가 혼합되어\
있습니다. 이것은 PATH에서 일치 항목을 검색 할 때 가장 일반적인 실제 문제 일 것입니다.- 한 가지 예외가 있습니다. 상대 경로
C:
(C 드라이브의 현재 작업 디렉터리를 의미)가 C 드라이브C:\
의 루트 디렉터리를 의미하는 것과 매우 다릅니다.
- 한 가지 예외가 있습니다. 상대 경로
일부 경로에는 대체 짧은 이름
이 있습니다. 이전 8.3 표준을 충족하지 않는 모든 경로에는 표준을 충족하는 대체 짧은 형식이 있습니다. 이것은 특히 비즈니스 설정에서 자주 보았던 또 다른 PATH 문제입니다.Windows는 경로 내에서
/
및\
폴더 구분 기호를 모두 허용합니다 .
이것은 자주 보이지는 않지만/
대신 대신 사용하여 경로를 지정할 수 있으며\
PATH 내에서 잘 작동합니다 (다른 많은 Windows 컨텍스트에서도 마찬가지 임).Windows는 연속적인 폴더 구분 기호를 하나의 논리적 구분 기호로 취급합니다.
C : \ FOLDER \\ 및 C : \ FOLDER \는 동일합니다. 이것은 개발자가 일반적으로\
후행이\
이미 존재 하는지 확인하지 않고 경로에 추가 할 수 있기 때문에 경로를 다룰 때 많은 상황에서 실제로 도움 이됩니다. 그러나 이것은 정확한 문자열 일치를 수행하려고 할 때 분명히 문제를 일으킬 수 있습니다.- 예외 :이 (
C:
가C:\
)뿐만 아니라C:\
(유효한 경로)가C:\\
(유효하지 않은 경로)와 ( 과) 다릅니다 .
- 예외 :이 (
Windows는 파일 및 디렉토리 이름에서 후행 점과 공백을 제거합니다.
"C:\test. "
와 동일합니다"C:\test"
.현재
.\
및 상위..\
폴더 지정자는 경로 내에 나타날
수 있습니다. 실제에서는 볼 수 없을 것 같지만 다음과 같은C:\.\parent\child\..\.\child\
것은 다음과 같습니다.C:\parent\child
경로는 선택적으로 큰 따옴표로 묶을 수 있습니다.
경로는와 같은 특수 문자로부터 보호하기 위해 종종 따옴표로 묶여<space>
,
;
^
&
=
있습니다. 실제로 경로 앞, 내부 및 / 또는 뒤에 임의의 수의 따옴표가 나타날 수 있습니다. 특수 문자에 대한 보호 목적을 제외하고는 Windows에서 무시됩니다. 경로에를 포함하지 않는 한 PATH 내에서 따옴표가 필요하지;
않지만 따옴표는 항상 존재할 수 있습니다.경로는 정규화되거나 상대적 일 수 있습니다.
정규화 된 경로는 파일 시스템 내에서 정확히 하나의 특정 위치를 가리 킵니다. 상대 경로 위치는 현재 작업 볼륨 및 디렉토리의 값에 따라 변경됩니다. 상대 경로에는 세 가지 주요 특징이 있습니다.D:
볼륨 D의 현재 작업 디렉토리에 상대적입니다.\myPath
현재 작업량을 기준으로합니다 (C :, D : 등일 수 있음).myPath
현재 작업 볼륨 및 디렉토리에 상대적입니다.
PATH 내에 상대 경로를 포함하는 것은 완벽하게 합법적입니다. Unix는 기본적으로 현재 디렉토리를 검색하지 않으므로 Unix PATH에는 종종
.\
. 그러나 Windows는 기본적으로 현재 디렉터리를 검색하므로 Windows PATH에서 상대 경로는 거의 없습니다.
따라서 PATH에 이미 경로가 포함되어 있는지 확실하게 확인하려면 주어진 경로를 표준 (표준) 형식으로 변환하는 방법이 필요합니다. ~s
6 부분적 주소 제 문제 - 변수 확장 인수가 사용 개질제 주소 문제 하나가 간단한 방법으로 ~s
인용 둘러싸 개질제를 제거합니다하지만 보존 내부 인용. 비교 전에 모든 경로에서 따옴표를 명시 적으로 제거하여 문제 7을 완전히 해결할 수 있습니다. 경로가 물리적으로 존재하지 않는 경우 ~s
수정자는 \
경로에를 추가 하지 않으며 경로를 유효한 8.3 형식으로 변환하지 않습니다.
문제 ~s
는 상대 경로를 정규화 된 경로로 변환한다는 것입니다. 상대 경로가 정규화 된 경로와 일치해서는 안되므로 문제 8에서는 문제가됩니다. FINDSTR 정규식을 사용하여 경로를 정규화 된 경로 또는 상대 경로로 분류 할 수 있습니다. 정규화 된 일반 경로는로 시작해야 <letter>:<separator>
하지만으로 시작 하지 않아야합니다 <letter>:<separator><separator>
. 여기서 <separator>는 \
또는 /
입니다. UNC 경로는 항상 정규화되어 있으며 \\
. 정규화 된 경로를 비교할 때 우리는~s
수정 자. 상대 경로를 비교할 때 원시 문자열을 사용합니다. 마지막으로 정규화 된 경로를 상대 경로와 비교하지 않습니다. 이 전략은 문제 8에 대한 좋은 실용적인 솔루션을 제공합니다. 유일한 제한은 논리적으로 동일한 두 개의 상대 경로가 일치하지 않는 것으로 처리 될 수 있다는 것입니다. 그러나 이는 Windows PATH에서 상대 경로가 드물기 때문에 사소한 문제입니다.
이 문제를 복잡하게 만드는 몇 가지 추가 문제가 있습니다.
9) 특수 문자가 포함 된 PATH를 처리 할 때 정상적인 확장은 신뢰할 수 없습니다.
특수 문자는 PATH 내에서 인용 할 필요가 없지만 그럴 수 있습니다. 따라서 PATH like C:\THIS & THAT;"C:\& THE OTHER THING"
는 완벽하게 유효하지만 "%PATH%"
및 둘 다 %PATH%
실패 하기 때문에 간단한 확장을 사용하여 안전하게 확장 할 수 없습니다 .
10) 경로 구분 기호는 경로 이름 내에서도 유효합니다.
A ;
는 PATH 내 경로를 구분하는 데 사용되지만 경로 내 ;
에서 유효한 문자 일 수도 있습니다.이 경우 경로를 인용해야합니다. 이로 인해 구문 분석 문제가 발생합니다.
jeb은 '예쁜 인쇄'창 % PATH % 변수 에서 문제 9와 10을 모두 해결했습니다 - ';'에서 분할하는 방법 CMD 셸에서
따라서 ~s
수정 자 및 경로 분류 기술을 jeb의 PATH 파서 변형과 함께 결합하여 주어진 경로가 PATH 내에 이미 존재하는지 확인하기위한 거의 완벽한 솔루션을 얻을 수 있습니다. 이 함수는 배치 파일 내에서 포함 및 호출되거나 독립형으로 자체 inPath.bat 배치 파일로 호출 될 수 있습니다. 많은 코드처럼 보이지만 절반 이상이 주석입니다.
@echo off
:inPath pathVar
::
:: Tests if the path stored within variable pathVar exists within PATH.
::
:: The result is returned as the ERRORLEVEL:
:: 0 if the pathVar path is found in PATH.
:: 1 if the pathVar path is not found in PATH.
:: 2 if pathVar is missing or undefined or if PATH is undefined.
::
:: If the pathVar path is fully qualified, then it is logically compared
:: to each fully qualified path within PATH. The path strings don't have
:: to match exactly, they just need to be logically equivalent.
::
:: If the pathVar path is relative, then it is strictly compared to each
:: relative path within PATH. Case differences and double quotes are
:: ignored, but otherwise the path strings must match exactly.
::
::------------------------------------------------------------------------
::
:: Error checking
if "%~1"=="" exit /b 2
if not defined %~1 exit /b 2
if not defined path exit /b 2
::
:: Prepare to safely parse PATH into individual paths
setlocal DisableDelayedExpansion
set "var=%path:"=""%"
set "var=%var:^=^^%"
set "var=%var:&=^&%"
set "var=%var:|=^|%"
set "var=%var:<=^<%"
set "var=%var:>=^>%"
set "var=%var:;=^;^;%"
set var=%var:""="%
set "var=%var:"=""Q%"
set "var=%var:;;="S"S%"
set "var=%var:^;^;=;%"
set "var=%var:""="%"
setlocal EnableDelayedExpansion
set "var=!var:"Q=!"
set "var=!var:"S"S=";"!"
::
:: Remove quotes from pathVar and abort if it becomes empty
set "new=!%~1:"=!"
if not defined new exit /b 2
::
:: Determine if pathVar is fully qualified
echo("!new!"|findstr /i /r /c:^"^^\"[a-zA-Z]:[\\/][^\\/]" ^
/c:^"^^\"[\\][\\]" >nul ^
&& set "abs=1" || set "abs=0"
::
:: For each path in PATH, check if path is fully qualified and then do
:: proper comparison with pathVar.
:: Exit with ERRORLEVEL 0 if a match is found.
:: Delayed expansion must be disabled when expanding FOR variables
:: just in case the value contains !
for %%A in ("!new!\") do for %%B in ("!var!") do (
if "!!"=="" endlocal
for %%C in ("%%~B\") do (
echo(%%B|findstr /i /r /c:^"^^\"[a-zA-Z]:[\\/][^\\/]" ^
/c:^"^^\"[\\][\\]" >nul ^
&& (if %abs%==1 if /i "%%~sA"=="%%~sC" exit /b 0) ^
|| (if %abs%==0 if /i "%%~A"=="%%~C" exit /b 0)
)
)
:: No match was found so exit with ERRORLEVEL 1
exit /b 1
함수는 다음과 같이 사용할 수 있습니다 (배치 파일의 이름이 inPath.bat라고 가정).
set test=c:\mypath
call inPath test && (echo found) || (echo not found)
일반적으로 PATH 내에 경로가 있는지 확인하는 이유는 경로가없는 경우 경로를 추가하기 때문입니다. 이것은 일반적으로
path %path%;%newPath%
. 그러나 9 호는 이것이 어떻게 신뢰할 수 없는지 보여줍니다.
또 다른 문제는 특히 지연된 확장을 활성화하거나 비활성화 한 상태로 함수를 호출 할 수있는 경우 함수 끝에서 ENDLOCAL 장벽을 통해 최종 PATH 값을 반환하는 방법입니다. 이스케이프 처리되지 않은 !
경우 지연된 확장이 활성화 된 경우 값이 손상됩니다.
이러한 문제는 jeb이 여기에서 발명 한 놀라운 안전한 반환 기술을 사용하여 해결됩니다. http://www.dostips.com/forum/viewtopic.php?p=6930#p6930
@echo off
:addPath pathVar /B
::
:: Safely appends the path contained within variable pathVar to the end
:: of PATH if and only if the path does not already exist within PATH.
::
:: If the case insensitive /B option is specified, then the path is
:: inserted into the front (Beginning) of PATH instead.
::
:: If the pathVar path is fully qualified, then it is logically compared
:: to each fully qualified path within PATH. The path strings are
:: considered a match if they are logically equivalent.
::
:: If the pathVar path is relative, then it is strictly compared to each
:: relative path within PATH. Case differences and double quotes are
:: ignored, but otherwise the path strings must match exactly.
::
:: Before appending the pathVar path, all double quotes are stripped, and
:: then the path is enclosed in double quotes if and only if the path
:: contains at least one semicolon.
::
:: addPath aborts with ERRORLEVEL 2 if pathVar is missing or undefined
:: or if PATH is undefined.
::
::------------------------------------------------------------------------
::
:: Error checking
if "%~1"=="" exit /b 2
if not defined %~1 exit /b 2
if not defined path exit /b 2
::
:: Determine if function was called while delayed expansion was enabled
setlocal
set "NotDelayed=!"
::
:: Prepare to safely parse PATH into individual paths
setlocal DisableDelayedExpansion
set "var=%path:"=""%"
set "var=%var:^=^^%"
set "var=%var:&=^&%"
set "var=%var:|=^|%"
set "var=%var:<=^<%"
set "var=%var:>=^>%"
set "var=%var:;=^;^;%"
set var=%var:""="%
set "var=%var:"=""Q%"
set "var=%var:;;="S"S%"
set "var=%var:^;^;=;%"
set "var=%var:""="%"
setlocal EnableDelayedExpansion
set "var=!var:"Q=!"
set "var=!var:"S"S=";"!"
::
:: Remove quotes from pathVar and abort if it becomes empty
set "new=!%~1:"^=!"
if not defined new exit /b 2
::
:: Determine if pathVar is fully qualified
echo("!new!"|findstr /i /r /c:^"^^\"[a-zA-Z]:[\\/][^\\/]" ^
/c:^"^^\"[\\][\\]" >nul ^
&& set "abs=1" || set "abs=0"
::
:: For each path in PATH, check if path is fully qualified and then
:: do proper comparison with pathVar. Exit if a match is found.
:: Delayed expansion must be disabled when expanding FOR variables
:: just in case the value contains !
for %%A in ("!new!\") do for %%B in ("!var!") do (
if "!!"=="" setlocal disableDelayedExpansion
for %%C in ("%%~B\") do (
echo(%%B|findstr /i /r /c:^"^^\"[a-zA-Z]:[\\/][^\\/]" ^
/c:^"^^\"[\\][\\]" >nul ^
&& (if %abs%==1 if /i "%%~sA"=="%%~sC" exit /b 0) ^
|| (if %abs%==0 if /i %%A==%%C exit /b 0)
)
)
::
:: Build the modified PATH, enclosing the added path in quotes
:: only if it contains ;
setlocal enableDelayedExpansion
if "!new:;=!" neq "!new!" set new="!new!"
if /i "%~2"=="/B" (set "rtn=!new!;!path!") else set "rtn=!path!;!new!"
::
:: rtn now contains the modified PATH. We need to safely pass the
:: value accross the ENDLOCAL barrier
::
:: Make rtn safe for assignment using normal expansion by replacing
:: % and " with not yet defined FOR variables
set "rtn=!rtn:%%=%%A!"
set "rtn=!rtn:"=%%B!"
::
:: Escape ^ and ! if function was called while delayed expansion was enabled.
:: The trailing ! in the second assignment is critical and must not be removed.
if not defined NotDelayed set "rtn=!rtn:^=^^^^!"
if not defined NotDelayed set "rtn=%rtn:!=^^^!%" !
::
:: Pass the rtn value accross the ENDLOCAL barrier using FOR variables to
:: restore the % and " characters. Again the trailing ! is critical.
for /f "usebackq tokens=1,2" %%A in ('%%^ ^"') do (
endlocal & endlocal & endlocal & endlocal & endlocal
set "path=%rtn%" !
)
exit /b 0
한동안 배치 파일 프로그래밍을하지 않았지만 :
echo ;%PATH%; | find /C /I ";<string>;"
문자열이 발견되지 않으면 0을, 발견하면 1 이상을 제공해야합니다.
편집 : Panos 덕분에 대소 문자를 구분하지 않는 플래그가 추가되었습니다.
경로에 무언가가 있는지 확인하는 또 다른 방법은 거기에 있으면 실패하지 않을 무고한 실행 파일을 실행하고 결과를 확인하는 것입니다. 예를 들어, 다음 코드 조각 은 maven 이 경로에 있는지 확인합니다 .
mvn --help > NUL 2> NUL
if errorlevel 1 goto mvnNotInPath
그래서 mvn --help 를 실행 하고 출력을 무시 하려고합니다 (maven이 있으면 실제로 도움말을보고 싶지 않습니다) (> NUL). 또한 maven을 찾을 수없는 경우 오류 메시지를 표시하지 않습니다 (2> NUL).
여기에 답변을 읽은 후 나는보기의 새로운 지점을 제공 할 수 있다고 생각 :이 질문의 목적을 알고있는 경우 특정 실행 파일의 경로가있는 경우 에 존재 %PATH%
하고 있지 않은 경우 (삽입하고, 이 유일한 이유는 할 그, 제 생각에) 약간 다른 방식으로 해결 될 수 있습니다. "특정 실행 프로그램의 디렉토리가 % PATH %에 있는지 확인하는 방법"? 이 질문은 다음과 같이 쉽게 해결할 수 있습니다.
for %%p in (programname.exe) do set "progpath=%%~$PATH:p"
if not defined progpath (
rem The path to programname.exe don't exist in PATH variable, insert it:
set "PATH=%PATH%;C:\path\to\progranname"
)
실행 파일의 확장자를 모르면 모두 검토하십시오.
set "progpath="
for %%e in (%PATHEXT%) do (
if not defined progpath (
for %%p in (programname.%%e) do set "progpath=%%~$PATH:p"
)
)
사용 for
및 delims
(, 당신은 필드의 임의의 수를 캡처 할 수 없습니다 아담이 지적 뿐만 아니라) 대신 루핑 기술을 사용 할 수 있도록. 다음 명령 스크립트는 PATH
별도의 행에 환경 변수의 각 경로를 나열 합니다.
@echo off
setlocal
if "%~1"=="" (
set PATHQ=%PATH%
) else (
set PATHQ=%~1 )
:WHILE
if "%PATHQ%"=="" goto WEND
for /F "delims=;" %%i in ("%PATHQ%") do echo %%i
for /F "delims=; tokens=1,*" %%i in ("%PATHQ%") do set PATHQ=%%j
goto WHILE
:WEND
그것은 고전적인 시뮬레이션 동안 ... WEND의 많은 프로그래밍 언어에서 발견되는 구조를. 이 기능을 사용하면 다음과 같은 findstr
것을 사용 하여 특정 경로를 필터링하고 찾을 수 있습니다 . 예를 들어, 위의 스크립트를라는 파일에 저장 한 경우 tidypath.cmd
다음 findstr
은 표준 프로그램 디렉토리 아래에서 경로를 찾는 방법입니다 (대소 문자를 구분하지 않는 일치 사용).
> tidypath | findstr /i "%ProgramFiles%"
이것은 정확하지만 대소 문자를 구분하지 않는 일치를 찾을 것이므로 후행 백 슬래시 등을 염두에 두십시오.
for %P in ("%path:;=";"%") do @if /i %P=="PATH_TO_CHECK" echo %P exists in PATH
또는 인수를받는 배치 파일 (예 : checkpath.bat)에서 :
@for %%P in ("%path:;=";"%") do @if /i %%P=="%~1" echo %%P exists in PATH
후자의 형식에서는 예 checkpath "%ProgramFiles%"
를 들어 지정된 경로가 PATH에 이미 있는지 확인하기 위해 호출 할 수 있습니다.
이 구현에서는 단일 경로 항목 내에 세미콜론이나 따옴표가 없다고 가정합니다.
for 루프를 사용하여 구현을 가져와 경로의 모든 요소를 반복하는 것으로 확장했습니다. for 루프를 반복 할 때마다 전체 경로 (% q 및 % r에 보관 됨)에서 경로 (% p)의 첫 번째 요소가 제거됩니다.
@echo off
SET MYPATHCOPY=%PATH%
:search
for /f "delims=; tokens=1,2*" %%p in ("%MYPATHCOPY%") do (
@echo %%~p
SET MYPATHCOPY=%%~q;%%~r
)
if "%MYPATHCOPY%"==";" goto done;
goto search;
:done
샘플 출력 :
Z:\>path.bat
C:\Program Files\Microsoft DirectX SDK (November 2007)\Utilities\Bin\x86
c:\program files\imagemagick-6.3.4-q16
C:\WINDOWS\system32
C:\WINDOWS
C:\SFU\common\
c:\Program Files\Debugging Tools for Windows
C:\Program Files\Nmap
아직 존재하지 않는 경우 PATH에 디렉토리를 추가하십시오.
set myPath=c:\mypath
For /F "Delims=" %%I In ('echo %PATH% ^| find /C /I "%myPath%"') Do set pathExists=%%I 2>Nul
If %pathExists%==0 (set PATH=%myPath%;%PATH%)
부분 문자열 대체를 사용하여 부분 문자열의 존재 여부를 테스트 할 수도 있습니다. 여기서 PATH_NQ를 생성하기 위해 따옴표를 제거한 다음 PATH_NQ에서 "c : \ mydir"을 제거하고 원본과 비교하여 변경된 사항이 있는지 확인합니다.
set PATH_NQ=%PATH:"=%
if not "%PATH_NQ%"=="%PATH_NQ:c:\mydir=%" goto already_in_path
set PATH=%PATH%;c:\mydir
:already_in_path
위의 답변 중 일부를 결합하여 주어진 경로 항목이 가능한 한 간결하고 명령 줄에 정크 에코가없는 지정된대로 정확하게 존재하는지 확인했습니다 .
set myPath=<pathToEnsure | %1>
echo ;%PATH%; | find /C /I ";%myPath%;" >nul
if %ERRORLEVEL% NEQ 0 set PATH=%PATH%;%myPath%
질문이 "이 cmd 스크립트 조각이 작동하지 않는 이유는 무엇입니까?"인 경우 대답은 for /f
줄 을 반복 한다는 것입니다 . delims
분할 필드에 선,하지만 당신은 단지에 첫 번째 필드를 캡처하고 있습니다 %%P
. for /f
루프를 사용 하여 임의의 수의 필드를 캡처하는 방법은 없습니다 .
그냥에 정교 Heyvoon의 (2015년 6월 8일) PowerShell을 사용하여 응답이 간단한 PowerShell 스크립트는 당신에게 % 경로 %에 대한 세부 사항을 제공해야
$env:Path -split ";" | % {"$(test-path $_);$_"}
독립적으로 확인할 수있는 이러한 종류의 출력 생성
True;C:\WINDOWS
True;C:\WINDOWS\system32
True;C:\WINDOWS\System32\Wbem
False;C:windows\System32\windowsPowerShell\v1.0\
False;C:\Program Files (x86)\Java\jre7\bin
경로 업데이트를 위해 재 조립하려면 :
$x=$null;foreach ($t in ($env:Path -split ";") ) {if (test-path $t) {$x+=$t+";"}};$x
rcar의 답변을 바탕으로 대상의 하위 문자열을 찾을 수 없는지 확인해야합니다.
if a%X%==a%PATH% echo %X% is in PATH
echo %PATH% | find /c /i ";%X%"
if errorlevel 1 echo %X% is in PATH
echo %PATH% | find /c /i "%X%;"
if errorlevel 1 echo %X% is in PATH
디렉토리가 이미 존재하는 경우 검색 경로에 디렉토리를 추가하지 않기를 원한다고 언급했습니다. 디렉토리를 경로에 영구적으로 저장 하시겠습니까, 아니면 배치 파일을 위해 임시로 저장 하시겠습니까?
당신이 PATH에 영구적으로 디렉토리를 추가하거나 제거하려는 경우, 관리 작업에 대한 Windows 리소스 키트 도구의 경로 관리자 (PathMan.exe에) 유틸리티를 한 번 봐 걸릴 http://support.microsoft.com/kb/927229를 . 이를 통해 시스템 및 사용자 경로의 구성 요소를 추가하거나 제거 할 수 있으며 중복 항목과 같은 이상을 처리합니다.
배치 파일의 경우 일시적으로 만 경로를 수정해야하는 경우 경로의 중복 항목으로 인해 약간의 성능 저하 위험이있는 경로 앞에 추가 경로를 추가하기 만하면됩니다.
이 버전은 상당히 잘 작동합니다. 단순히 vim71이 경로에 있는지 확인하고 그렇지 않은 경우 앞에 추가합니다.
@echo off
echo %PATH% | find /c /i "vim71" > nul
if not errorlevel 1 goto jump
PATH = C:\Program Files\Vim\vim71\;%PATH%
:jump
이 데모는 오류 수준 논리를 설명하기위한 것입니다.
@echo on
echo %PATH% | find /c /i "Windows"
if "%errorlevel%"=="0" echo Found Windows
echo %PATH% | find /c /i "Nonesuch"
if "%errorlevel%"=="0" echo Found Nonesuch
vim71 코드에서 논리는 오류 수준 1이 오류 수준> = 1과 동일하기 때문에 반대입니다. 오류 수준 0은 항상 참으로 평가되므로 " not errorlevel 1
"이 사용됩니다.
setlocal 및 endlocal을 사용하여 환경 설정을 지역화하는 경우 포스트 스크립트 검사가 필요하지 않을 수 있습니다.
@echo off
setlocal
PATH = C:\Program Files\Vim\vim71\;%PATH%
rem your code here
endlocal
endlocal 후에는 원래 경로로 돌아 왔습니다.
"addPath"스크립트에 대한 주석. 공백이있는 경로를 제공하면 토합니다.
예 : addPath "c : \ Program Files (x86) \ Microsoft SDKs \ Windows \ v7.0A \ Bin"호출
결과 : '파일'은 내부 또는 외부 명령, 작동 가능한 프로그램 또는 배치 파일로 인식되지 않습니다.
일반적으로 이것은 경로에 exe / dll을 넣는 것입니다. 이 파일이 다른 곳에 나타나지 않는 한 :
@echo off
where /q <put filename here>
if %errorlevel% == 1 (
setx PATH "%PATH%;<additional path stuff>"
) else (
echo "already set path"
)
이것은 문자열 교체를 사용하는 Kevin Edwards의 답변에 대한 변형입니다. 기본 패턴은 다음과 같습니다.
IF "%PATH:new_path=%" == "%PATH%" PATH=%PATH%;new_path
예를 들면 :
IF "%PATH:C:\Scripts=%" == "%PATH%" PATH=%PATH%;C:\Scripts
간단히 말해, 환경 변수 new_path
에서 제거 / 교체 를 시도하는 조건부 테스트를 만듭니다 PATH
. 경우 new_path
존재하지 않는 상태가 성공하고이 new_path
추가됩니다 PATH
처음. new_path
이미 존재하는 경우 조건이 실패하고 new_path
두 번째로 추가하지 않습니다 .
PoweShell을 사용하여이 작업을 수행 할 수 있습니다.
Test-Path $ENV:SystemRoot\YourDirectory
Test-Path C:\Windows\YourDirectory
이것은 TRUE
또는FALSE
짧고 단순하며 쉽습니다!
대안으로 :
PATH
변수 를 검색 할 폴더 에서 컴퓨터의 다른 파일이 가질 것으로 예상 할 수없는 비정상적인 이름으로 임시 파일을 만듭니다.일부 환경 변수 (일반적으로
PATH
)로 정의 된 디렉토리 목록을 조회하여 파일 검색을 수행 할 수있는 표준 배치 스크립팅 구성을 사용합니다 .검색 결과가 해당 경로와 일치하는지 확인하고 결과를 표시합니다.
임시 파일을 삭제하십시오.
다음과 같이 보일 수 있습니다.
@ECHO OFF
SET "mypath=D:\the\searched-for\path"
SET unusualname=nowthisissupposedtobesomeveryunusualfilename
ECHO.>"%mypath%\%unusualname%"
FOR %%f IN (%unusualname%) DO SET "foundpath=%%~dp$PATH:f"
ERASE "%mypath%\%unusualname%"
IF "%mypath%" == "%foundpath%" (
ECHO The dir exists in PATH
) ELSE (
ECHO The dir DOES NOT exist in PATH
)
알려진 문제 :
이 메서드는 디렉터리가 존재하는 경우에만 작동 할 수 있습니다 (항상 그런 것은 아닙니다).
디렉토리에서 파일을 생성 / 삭제하면 '수정 된 날짜 / 시간'속성에 영향을줍니다 (때로는 바람직하지 않은 결과 일 수 있음).
Making up a globally unique file name in one's mind cannot be considered very reliable. Generating such a name is itself not a trivial task.
This routine will search for a path\ or file.ext in the path variable it returns 0 if found. Path\ or file may contain spaces if quoted. If a variable is passed as the last argument it will be set to d:\path\file
.
@echo off&goto :PathCheck
:PathCheck.CMD
echo.PathCheck.CMD: Checks for existence of a path or file in %%PATH%% variable
echo.Usage: PathCheck.CMD [Checkpath] or [Checkfile] [PathVar]
echo.Checkpath must have a trailing \ but checkfile must not
echo.If Checkpath contains spaces use quotes ie. "C:\Check path\"
echo.Checkfile must not include a path, just the filename.ext
echo.If Checkfile contains spaces use quotes ie. "Check File.ext"
echo.Returns 0 if found, 1 if not or -1 if checkpath does not exist at all
echo.If PathVar is not in command line it will be echoed with surrounding quotes
echo.If PathVar is passed it will be set to d:\path\checkfile with no trailing \
echo.Then %%PathVar%% will be set to the fully qualified path to Checkfile
echo.Note: %%PathVar%% variable set will not be surrounded with quotes
echo.To view the path listing line by line use: PathCheck.CMD /L
exit/b 1
:PathCheck
if "%~1"=="" goto :PathCheck.CMD
setlocal EnableDelayedExpansion
set "PathVar=%~2"
set "pth="
set "pcheck=%~1"
if "%pcheck:~-1%" equ "\" (
if not exist %pcheck% endlocal&exit/b -1
set/a pth=1
)
for %%G in ("%path:;=" "%") do (
set "Pathfd=%%~G\"
set "Pathfd=!Pathfd:\\=\!"
if /i "%pcheck%" equ "/L" echo.!Pathfd!
if defined pth (
if /i "%pcheck%" equ "!Pathfd!" endlocal&exit/b 0
) else (
if exist "!Pathfd!%pcheck%" goto :CheckfileFound
)
)
endlocal&exit/b 1
:CheckfileFound
endlocal&(
if not "%PathVar%"=="" (
call set "%~2=%Pathfd%%pcheck%"
) else (echo."%Pathfd%%pcheck%")
exit/b 0
)
-contains
worked for me
$pathToCheck = "c:\some path\to\a\file.txt"
$env:Path - split ';' -contains $pathToCheck
To add the path when it does not exist yet I use
$pathToCheck = "c:\some path\to\a\file.txt"
if(!($env:Path -split ';' -contains $vboxPath)) {
$documentsDir = [Environment]::GetFolderPath("MyDocuments")
$profileFilePath = Join-Path $documentsDir "WindowsPowerShell/profile.ps1"
Out-File -FilePath $profileFilePath -Append -Force -Encoding ascii -InputObject "`$env:Path += `";$pathToCheck`""
Invoke-Expression -command $profileFilePath
}
참고URL : https://stackoverflow.com/questions/141344/how-to-check-if-directory-exists-in-path
'development' 카테고리의 다른 글
Visual Studio Code : 각 찾기 항목 선택 (0) | 2020.12.06 |
---|---|
Ruby를 Homebrew로 업데이트하는 방법은 무엇입니까? (0) | 2020.12.06 |
jQuery를 사용하여 하이퍼 링크 비활성화 (0) | 2020.12.06 |
release () 예외 후에 호출 된 메서드는 Android 카메라로 다시 시작할 수 없습니다. (0) | 2020.12.06 |
양말 프록시를 통해 파이썬 요청을 작동시키는 방법 (0) | 2020.12.06 |