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의 조합도 가능하네요. ^^ 정보 감사합니다.
정성태

... 121  122  123  124  125  126  127  128  129  [130]  131  132  133  134  135  ...
NoWriterDateCnt.TitleFile(s)
1805정성태11/5/201421853.NET Framework: 476. Visual Studio에서 Mono용 Profiler 개발 [3]파일 다운로드1
1804정성태11/5/201428107.NET Framework: 475. ETW(Event Tracing for Windows)를 C#에서 사용하는 방법 [9]파일 다운로드1
1803정성태11/4/201420213오류 유형: 261. Windows Server Backup 오류 - Error in backup of E:\$Extend\$RmMetadata\$TxfLog
1802정성태11/4/201422194오류 유형: 260. 이벤트 로그 - Windows Error Reporting / AEAPPINVW8
1801정성태11/4/201427412오류 유형: 259. 이벤트 로그 - Windows Error Reporting / IPX Assertion / KorIME.exe [1]
1800정성태11/4/201418215오류 유형: 258. 이벤트 로그 - Starting a SMART disk polling operation in Automatic mode.
1799정성태11/4/201422945오류 유형: 257. 이벤트 로그 - The WMI Performance Adapter service entered the stopped state.
1798정성태11/4/201431702오류 유형: 256. 이벤트 로그 - The WinHTTP Web Proxy Auto-Discovery Service service entered the stopped state. [1]
1797정성태11/4/201417385오류 유형: 255. 이벤트 로그 - The Adobe Flash Player Update Service service entered the stopped state.
1796정성태10/30/201424425개발 환경 구성: 249. Visual Studio 2013에서 Mono 컴파일하는 방법
1795정성태10/29/201426955개발 환경 구성: 248. Lync 2013 서버 설치 방법
1794정성태10/29/201422376개발 환경 구성: 247. "Microsoft Office 365 Enterprise E3" 서비스에 대한 간략 소개
1793정성태10/27/201423011.NET Framework: 474. C# - chromiumembedded 사용 - 두 번째 이야기 [2]파일 다운로드1
1792정성태10/27/201423152.NET Framework: 473. WebClient 객체에 쿠키(Cookie)를 사용하는 방법
1791정성태10/22/201422885VC++: 83. G++ - 템플릿 클래스의 iterator 코드 사용에서 발생하는 컴파일 오류 [5]
1790정성태10/22/201418409오류 유형: 254. NETLOGON Service is paused on [... AD Server...]
1789정성태10/22/201421005오류 유형: 253. 이벤트 로그 - The client-side extension could not remove user policy settings for '...'
1788정성태10/22/201423083VC++: 82. COM 프로그래밍에서 HRESULT 타입의 S_FALSE는 실패일까요? 성공일까요? [2]
1787정성태10/22/201431256오류 유형: 252. COM 개체 등록시 0x8002801C 오류가 발생한다면?
1786정성태10/22/201432611디버깅 기술: 65. 프로세스 비정상 종료 시 "Debug Diagnostic Tool"를 이용해 덤프를 남기는 방법 [3]파일 다운로드1
1785정성태10/22/201421804오류 유형: 251. 이벤트 로그 - Load control template file /_controltemplates/TaxonomyPicker.ascx failed [1]
1784정성태10/22/201429912.NET Framework: 472. C/C++과 C# 사이의 메모리 할당/해제 방법파일 다운로드1
1783정성태10/21/201423338VC++: 81. 프로그래밍에서 borrowing의 개념
1782정성태10/21/201420075오류 유형: 250. 이벤트 로그 - Application Server job failed for service instance Microsoft.Office.Server.Search.Administration.SearchServiceInstance
1781정성태10/21/201420491디버깅 기술: 64. new/delete의 짝이 맞는 경우에도 메모리 누수가 발생한다면?
1780정성태10/15/201424123오류 유형: 249. The application-specific permission settings do not grant Local Activation permission for the COM Server application with CLSID
... 121  122  123  124  125  126  127  128  129  [130]  131  132  133  134  135  ...