Microsoft MVP성태의 닷넷 이야기
글쓴 사람
홈페이지
첨부 파일
 

윈도우 배치(Batch) 스크립트에서 날짜/시간 문자열을 구하는 방법

그동안, 배치 스크립트에서 다음과 같은 코드로 로그 파일의 접미사로 사용했는데요.

SET DATETEXT=%date:~0,4%%date:~5,2%%date:~8,2%
SET TIMETEXT=%time:~0,2%%time:~3,2%%time:~6,2%

echo %DATETEXT%_%TIMETEXT%
SET LOGFILENAME=result_%DATETEXT%_%TIMETEXT%.log

이게 좀 문제가 있군요. ^^

가령, 위의 스크립트는 날짜가 yyyy-MM-dd, 시간은 tt hh:mm과 같은 식으로 출력하도록 설정된 윈도우에서만 잘 동작합니다. 일례로 영어권 윈도우 운영체제에서는 다음과 같이 아예 엉망이 되어 버립니다.

C:\> SET DATETEXT=%date:~0,4%%date:~5,2%%date:~8,2%

C:\> SET TIMETEXT=%time:~0,2%%time:~3,2%%time:~6,2%

C:\> echo %DATETEXT%_%TIMETEXT%
10/1/218_152045

사실, 한국어 윈도우에서도 문제가 있는 것이 밤 0시인 경우에는 다음과 같은 식으로 나오기까지 합니다.

// 2018년 10월 16일 0시 16분 55초

20181016_ 01655

음... ^^; 분명히 개선이 필요하군요. 다행히 검색해 보면 다양한 해결 방법이 있습니다.

Creating a file name as a timestamp in a batch job
; https://stackoverflow.com/questions/1064557/creating-a-file-name-as-a-timestamp-in-a-batch-job/18687568

그중에서, 개인적으로 PowerShell을 이용한 해법이 가장 나아 보입니다.

REM WriteLog.bat

for /f %%i in ('powershell -c "get-date -format yyyyMMdd_HHmmss"') do set DATETIME=%%i
SET LOGFILENAME=result_%DATETIME%.log

echo %LOGFILENAME%

[출력 결과]

result_20181016_002818.log




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





[최초 등록일: ]
[최종 수정일: 10/16/2018 ]

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

비밀번호

댓글 쓴 사람
 




1  2  3  4  5  6  7  8  9  10  11  12  [13]  14  15  ...
NoWriterDateCnt.TitleFile(s)
11955정성태6/20/20191221Math: 60. C# - 로지스틱 회귀를 이용한 분류파일 다운로드1
11954정성태6/20/20191669오류 유형: 550. scp - sudo: no tty present and no askpass program specified
11953정성태6/20/20191027오류 유형: 549. The library 'libhostpolicy.so' required to execute the application was not found in '...'
11952정성태6/20/20191294Linux: 16. 우분투, Centos의 Netbios 호스트 이름 풀이 방법
11951정성태6/20/20191504오류 유형: 548. scp 연결 시 "Permission denied" 오류 및 "WARNING: REMOTE HOST IDENTIFICATION HAS CHANGED!" 경고
11950정성태6/18/20191650.NET Framework: 845. C# - 윈도우 작업 관리자와 리소스 모니터의 메모리 값을 구하는 방법
11949정성태6/18/2019885오류 유형: 547. CoreCLR Profiler 예제 프로젝트 빌드 시 컴파일 오류 유형
11948정성태6/17/20191008Linux: 15. 리눅스 환경의 Visual Studio Code에서 TFS 서버 연동
11947정성태9/25/20191329Linux: 14. 리눅스 환경에서 TFS 서버 연동
11946정성태6/17/20191727개발 환경 구성: 445. C# - MathNet으로 정규 분포를 따르는 데이터를 생성, PLplot으로 Histogram 표현파일 다운로드1
11945정성태6/25/20191361Linux: 13. node.js에서 syslog로 출력하는 방법
11944정성태6/16/20194236Linux: 12. Ubuntu 16.04/18.04에서 node.js 최신 버전 설치 방법
11943정성태6/15/20191566.NET Framework: 844. C# - 박싱과 언박싱 [1]
11942정성태6/20/20194552개발 환경 구성: 444. 로컬의 Visual Studio Code로 원격 리눅스 머신에 접속해 개발하는 방법 [1]
11941정성태6/13/20191028오류 유형: 546. "message NETSDK1057: You are using a preview version of .NET Core" 빌드 경고 없애는 방법
11940정성태6/13/2019927개발 환경 구성: 443. Visual Studio의 Connection Manager 기능(Remote SSH 관리)을 위한 명령행 도구파일 다운로드1
11939정성태6/13/20191033오류 유형: 545. Managed Debugging Assistant 'FatalExecutionEngineError'
11938정성태6/12/20191322Math: 59. C# - 웨이트 벡터 갱신식을 이용한 퍼셉트론 분류파일 다운로드1
11937정성태6/11/20193404개발 환경 구성: 442. .NET Core 3.0 preview 5를 이용해 Windows Forms/WPF 응용 프로그램 개발 [1]
11936정성태6/10/20191219Math: 58. C# - 최소 자승법의 1차, 2차 수렴 그래프 변화 확인파일 다운로드1
11935정성태5/7/20201430.NET Framework: 843. C# - PLplot 출력을 파일이 아닌 Window 화면으로 변경
11934정성태6/7/20191777VC++: 133. typedef struct와 타입 전방 선언으로 인한 C2371 오류파일 다운로드1
11933정성태6/7/20191718VC++: 132. enum 정의를 C++11의 enum class로 바꿀 때 유의할 사항파일 다운로드1
11932정성태6/7/20191377오류 유형: 544. C++ - fatal error C1017: invalid integer constant expression파일 다운로드1
11931정성태6/6/20191423개발 환경 구성: 441. C# - CairoSharp/GtkSharp 사용을 위한 프로젝트 구성 방법
11930정성태6/26/20191795.NET Framework: 842. .NET Reflection을 대체할 System.Reflection.Metadata 소개
1  2  3  4  5  6  7  8  9  10  11  12  [13]  14  15  ...