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

... 61  62  63  64  65  [66]  67  68  69  70  71  72  73  74  75  ...
NoWriterDateCnt.TitleFile(s)
12288정성태8/5/202015998오류 유형: 637. WCF - The protocol 'net.tcp' does not have an implementation of HostedTransportConfiguration type registered.
12287정성태8/5/202017430오류 유형: 636. C# - libdl.so를 DllImport로 연결 시 docker container 내에서 System.DllNotFoundException 예외 발생
12286정성태8/5/202018778개발 환경 구성: 501. .NET Core 용 container 이미지 만들 때 unzip이 필요한 경우
12285정성태8/4/202018448오류 유형: 635. 윈도우 10 업데이트 - 0xc1900209 [2]
12284정성태8/4/202017820디버깅 기술: 169. Hyper-V의 VM에 대한 메모리 덤프를 뜨는 방법
12283정성태8/3/202018707디버깅 기술: 168. windbg - 필터 드라이버 확인하는 확장 명령어(!fltkd) [2]
12282정성태8/2/202016554디버깅 기술: 167. windbg 디버깅 사례: AppDomain 간의 static 변수 사용으로 인한 crash (2)
12281정성태8/2/202020199개발 환경 구성: 500. (PDB 연결이 없는) DLL의 소스 코드 디버깅을 dotPeek 도구로 해결하는 방법
12280정성태8/2/202018307오류 유형: 634. 오라클 (평생) 무료 클라우드 VM 생성 후 SSH 접속 시 키 오류 발생 [2]
12279정성태7/29/202020044개발 환경 구성: 499. 닷넷에서 접근해보는 InterSystems의 Cache 데이터베이스파일 다운로드1
12278정성태7/23/202016671VS.NET IDE: 149. ("Binary was not built with debug information" 상태로) 소스 코드 디버깅이 안되는 경우
12277정성태7/23/202018620개발 환경 구성: 498. DEVPATH 환경 변수의 사용 예 - .NET Reflector의 (PDB 연결이 없는) DLL의 소스 코드 디버깅
12276정성태7/23/202017984.NET Framework: 930. 개발자를 위한 닷넷 어셈블리 바인딩 - DEVPATH 환경 변수
12275정성태7/22/202020187개발 환경 구성: 497. 닷넷에서 접근해보는 InterSystems의 IRIS Data Platform 데이터베이스파일 다운로드1
12274정성태7/21/202019535개발 환경 구성: 496. Azure - Blob Storage Account의 Location 이전 방법 [1]파일 다운로드1
12273정성태7/18/202022270개발 환경 구성: 495. Azure - Location이 다른 웹/DB 서버의 경우 발생하는 성능 하락
12272정성태7/16/202015469.NET Framework: 929. (StrongName의 버전 구분이 필요 없는) .NET Core 어셈블리 바인딩 규칙 [2]파일 다운로드1
12271정성태7/16/202018395.NET Framework: 928. .NET Framework의 Strong-named 어셈블리 바인딩 (2) - 런타임에 바인딩 리디렉션파일 다운로드1
12270정성태7/16/202019061오류 유형: 633. SSL_CTX_use_certificate_file - error:140AB18F:SSL routines:SSL_CTX_use_certificate:ee key too small
12269정성태7/16/202016310오류 유형: 632. .NET Core 웹 응용 프로그램 - The process was terminated due to an unhandled exception.
12268정성태7/15/202018906오류 유형: 631. .NET Core 웹 응용 프로그램 오류 - HTTP Error 500.35 - ANCM Multiple In-Process Applications in same Process
12267정성태7/15/202020998.NET Framework: 927. C# - 윈도우 프로그램에서 Credential Manager를 이용한 보안 정보 저장파일 다운로드1
12266정성태7/14/202017942오류 유형: 630. 사용자 계정을 지정해 CreateService API로 서비스를 등록한 경우 "Error 1069: The service did not start due to a logon failure." 오류발생
12265정성태7/10/202016790오류 유형: 629. Visual Studio - 웹 애플리케이션 실행 시 "Unable to connect to web server 'IIS Express'." 오류 발생
12264정성태7/9/202028102오류 유형: 628. docker: Error response from daemon: Conflict. The container name "..." is already in use by container "...".
12261정성태7/9/202019366VS.NET IDE: 148. 윈도우 10에서 .NET Core 응용 프로그램을 리눅스 환경에서 실행하는 2가지 방법 - docker, WSL 2 [5]
... 61  62  63  64  65  [66]  67  68  69  70  71  72  73  74  75  ...