Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 2개 있습니다.)
(시리즈 글이 12개 있습니다.)
개발 환경 구성: 1. batch 파일에서 실행한 exe에서 batch 실행 문맥의 환경 변수 설정
; https://www.sysnet.pe.kr/2/0/238

개발 환경 구성: 89. 배치(batch) 파일에서 또 다른 배치 파일을 동기 방식으로 실행 및 반환값 얻기
; https://www.sysnet.pe.kr/2/0/958

개발 환경 구성: 103. DOS batch - 동기 방식으로 원격 서비스 제어
; https://www.sysnet.pe.kr/2/0/989

개발 환경 구성: 144. 윈도우에서도 유닉스처럼 명령행으로 원격 접속하는 방법
; https://www.sysnet.pe.kr/2/0/1245

개발 환경 구성: 166. DOS - ping 결과에서 평균 응답 시간값 추출하기
; https://www.sysnet.pe.kr/2/0/1340

개발 환경 구성: 215. DOS batch - 하나의 .bat 파일에서 다중 .bat 파일을 (비동기로) 실행하는 방법
; https://www.sysnet.pe.kr/2/0/1629

개발 환경 구성: 242. 배치 파일에서 Thread.Sleep 효과를 주는 방법
; https://www.sysnet.pe.kr/2/0/1768

개발 환경 구성: 328. Visual Studio(devenv.exe)를 배치 파일(.bat)을 통해 실행하는 방법
; https://www.sysnet.pe.kr/2/0/11293

스크립트: 13. 윈도우 배치(Batch) 스크립트에서 날짜/시간 문자열을 구하는 방법
; https://www.sysnet.pe.kr/2/0/11742

스크립트: 16. cmd.exe의 for 문에서는 ERRORLEVEL이 설정되지 않는 문제
; https://www.sysnet.pe.kr/2/0/12039

스크립트: 66. Windows 디렉터리 경로를 WSL의 /mnt 포맷으로 구하는 방법 - 두 번째 이야기
; https://www.sysnet.pe.kr/2/0/13685

Windows: 276. 명령행에서 원격 서비스를 동기/비동기로 시작/중지
; https://www.sysnet.pe.kr/2/0/13861




배치(batch) 파일에서 또 다른 배치 파일을 동기 방식으로 실행 및 반환값 얻기

제목짓기 정말 어렵군요. ^^;

그냥 설명해 보면, 보통 다음과 같은 배치 파일들이 있을 때,

==== one.bat ====
@ECHO OFF 
echo ONE Batch
two.bat
echo ONE Complete

==== two.bat ==== 
@ECHO OFF
echo TWO Batch
echo TWO Complete

아마도 원래 의도했던 실행 결과는 다음과 같겠죠!

D:\...>one.bat
ONE Batch
TWO Batch
TWO Complete
ONE Complete
D:\...>

그런데, 배치 파일의 제어가 one.bat에서 two.bat로 완전히 넘어가버려서 two.bat 실행을 완료한 이후 one.bat로 돌아가지 않고 아래와 같이 바로 종료해 버립니다.

D:\...>one.bat
ONE Batch
TWO Batch
TWO Complete
D:\...>

바로 이런 경우, 원하는 결과를 얻으려면 다음과 같이 cmd.exe의 힘을 빌어야 합니다.

==== one.bat ====
@ECHO OFF
echo ONE Batch
cmd.exe /C two.bat
echo ONE Complete

이렇게 cmd.exe에 "/C" 옵션을 주면, 새로운 cmd.exe 명령어 쉘이 실행되고 그 내부에서 지정된 two.bat 파일을 실행한 후 부모 프로세스로 제어가 돌아가게 됩니다. 따라서, 의도했던 데로 one.bat의 남은 부분이 계속 실행됩니다. 또한, "/K" 옵션을 주어서 구현하는 것도 가능합니다. 이런 경우에는 대상 batch 파일에서 직접 exit 명령을 주어야 합니다.

==== one.bat ====
@ECHO OFF
echo ONE Batch
cmd.exe /K two.bat
echo ONE Complete

==== two.bat ==== 
@ECHO OFF
echo TWO Batch
echo TWO Complete
exit

자... 이제 슬슬 "반환값" 처리에 대해서 궁금해지는데요. 배치 파일에서 exit 구문을 사용하는 것으로 해결이 됩니다. 예를 들어, 아래는 무조건 "Error..." 문자열을 출력합니다.

==== one.bat ====
@ECHO OFF
echo ONE Batch
cmd.exe /C two.bat

if %ERRORLEVEL% == 0 ( goto NoError
) ELSE (
 echo Error...
)

:NoError
echo ONE Complete

==== two.bat ==== 
@ECHO OFF
echo TWO Batch
echo TWO Complete
exit 1

만약, "exit 0" 또는 그냥 "exit"로 두거나 "/C" 옵션으로 실행했으므로 명시하지 않으면 기본값으로 0이 적용되어 "goto NoError" 문이 실행됩니다.





[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]

[연관 글]






[최초 등록일: ]
[최종 수정일: 6/17/2021]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 



2010-12-07 04시56분
[ryujh] cmd.exe 로 two.bat 호출 대신 call two.bat 로도 할 수 있더군요.
이 때 two.bat 에서는 exit /b 1 으로 하면 됩니다.
[guest]
2010-12-07 06시02분
오~~~ 정말 call과 exit /b의 조합도 가능하네요. ^^ 정보 감사합니다.
정성태

... 91  92  93  94  95  96  97  [98]  99  100  101  102  103  104  105  ...
NoWriterDateCnt.TitleFile(s)
11484정성태4/11/201824691.NET Framework: 737. C# - async를 Task 타입이 아닌 사용자 정의 타입에 적용하는 방법파일 다운로드1
11483정성태4/10/201828001개발 환경 구성: 358. "Let's Encrypt"에서 제공하는 무료 SSL 인증서를 IIS에 적용하는 방법 (2) [1]
11482정성태4/10/201820453VC++: 126. CUDA Core 수를 알아내는 방법
11481정성태4/10/201832067개발 환경 구성: 357. CUDA의 인덱싱 관련 용어 - blockIdx, threadIdx, blockDim, gridDim
11480정성태4/9/201822096.NET Framework: 736. C# - API를 사용해 Azure에 접근하는 방법 [2]파일 다운로드1
11479정성태4/9/201817746.NET Framework: 735. Azure - PowerShell로 Access control(IAM)에 새로운 계정 만드는 방법
11478정성태11/8/201919970디버깅 기술: 115. windbg - 덤프 파일로부터 PID와 환경변수 등의 정보를 구하는 방법 [1]
11477정성태4/8/201817444오류 유형: 460. windbg - sos 명령어 수행 시 c0000006 오류 발생
11476정성태4/8/201819009디버깅 기술: 114. windbg - !threads 출력 결과로부터 닷넷 관리 스레드(System.Threading.Thread) 객체를 구하는 방법
11475정성태3/28/201821295디버깅 기술: 113. windbg - Thread.Suspend 호출 시 응용 프로그램 hang 현상에 대한 덤프 분석
11474정성태3/27/201819417오류 유형: 459. xperf: error: TEST.Event: Invalid flags. (0x3ec).
11473정성태3/22/201824584.NET Framework: 734. C# - Thread.Suspend 호출 시 응용 프로그램 hang 현상파일 다운로드2
11472정성태3/22/201818546개발 환경 구성: 356. GTX 1070, GTX 960, GT 640M의 cudaGetDeviceProperties 출력 결과
11471정성태3/20/201821928VC++: 125. CUDA로 작성한 RGB2RGBA 성능 [1]파일 다운로드1
11470정성태3/20/201824030오류 유형: 458. Visual Studio - CUDA 프로젝트 빌드 시 오류 C1189, expression must have a constant value
11469정성태3/19/201817047오류 유형: 457. error MSB3103: Invalid Resx file. Could not load file or assembly 'System.Windows.Forms, ...' or one of its dependencies.
11468정성태3/19/201816590오류 유형: 456. 닷넷 응용 프로그램 실행 시 0x80131401 예외 발생
11467정성태3/19/201816055오류 유형: 455. Visual Studio Installer - 업데이트 실패
11466정성태3/18/201817205개발 환경 구성: 355. 한 대의 PC에서 2개 이상의 DirectX 게임을 실행하는 방법
11463정성태3/15/201819546.NET Framework: 733. 스레드 간의 read/write 시에도 lock이 필요 없는 경우파일 다운로드1
11462정성태3/14/201822399개발 환경 구성: 354. HTTPS 호출에 대한 TLS 설정 확인하는 방법 [1]
11461정성태3/13/201825025오류 유형: 454. 윈도우 업데이트 설치 오류 - 0x800705b4 [1]
11460정성태3/13/201817499디버깅 기술: 112. windbg - 닷넷 메모리 덤프에서 전역 객체의 내용을 조사하는 방법
11459정성태3/13/201818312오류 유형: 453. Debug Diagnostic Tool에서 mscordacwks.dll을 찾지 못하는 문제
11458정성태2/21/201819285오류 유형: 452. This share requires the obsolete SMB1 protocol, which is unsafe and could expose your system to attack. [1]
11457정성태2/17/201823989.NET Framework: 732. C# - Task.ContinueWith 설명 [1]파일 다운로드1
... 91  92  93  94  95  96  97  [98]  99  100  101  102  103  104  105  ...