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)
11963정성태6/29/20191520Linux: 19. C# - .NET Core Unix Domain Socket 사용 예제
11962정성태6/27/2019970Math: 61. C# - 로지스틱 회귀를 이용한 선형분리 불가능 문제의 분류파일 다운로드1
11961정성태6/27/2019797Graphics: 37. C# - PLplot - 출력 모음(Family File Output)
11960정성태6/27/20191147Graphics: 36. C# - PLplot의 16색 이상을 표현하는 방법과 subpage를 이용한 그리드 맵 표현
11959정성태6/27/2019916Graphics: 35. matplotlib와 PLplot의 한글 처리
11958정성태6/25/20192311Linux: 18. C# - .NET Core Console로 리눅스 daemon 프로그램 만드는 방법 [1]
11957정성태6/24/20192701Windows: 160. WMI 쿼리를 명령행에서 간단하게 수행하는 wmic.exe [1]
11956정성태6/24/20191851Linux: 17. CentOS 7에서 .NET Core Web App 실행 환경 구성 [1]
11955정성태6/20/20191346Math: 60. C# - 로지스틱 회귀를 이용한 분류파일 다운로드1
11954정성태6/20/20191825오류 유형: 550. scp - sudo: no tty present and no askpass program specified
11953정성태6/20/20191115오류 유형: 549. The library 'libhostpolicy.so' required to execute the application was not found in '...'
11952정성태6/20/20191401Linux: 16. 우분투, Centos의 Netbios 호스트 이름 풀이 방법
11951정성태6/20/20191665오류 유형: 548. scp 연결 시 "Permission denied" 오류 및 "WARNING: REMOTE HOST IDENTIFICATION HAS CHANGED!" 경고
11950정성태6/18/20191808.NET Framework: 845. C# - 윈도우 작업 관리자와 리소스 모니터의 메모리 값을 구하는 방법
11949정성태6/18/2019957오류 유형: 547. CoreCLR Profiler 예제 프로젝트 빌드 시 컴파일 오류 유형
11948정성태6/17/20191128Linux: 15. 리눅스 환경의 Visual Studio Code에서 TFS 서버 연동
11947정성태9/25/20191423Linux: 14. 리눅스 환경에서 TFS 서버 연동
11946정성태6/17/20191935개발 환경 구성: 445. C# - MathNet으로 정규 분포를 따르는 데이터를 생성, PLplot으로 Histogram 표현파일 다운로드1
11945정성태6/25/20191486Linux: 13. node.js에서 syslog로 출력하는 방법
11944정성태6/16/20194662Linux: 12. Ubuntu 16.04/18.04에서 node.js 최신 버전 설치 방법
11943정성태6/15/20191671.NET Framework: 844. C# - 박싱과 언박싱 [1]
11942정성태6/20/20194967개발 환경 구성: 444. 로컬의 Visual Studio Code로 원격 리눅스 머신에 접속해 개발하는 방법 [1]
11941정성태6/13/20191112오류 유형: 546. "message NETSDK1057: You are using a preview version of .NET Core" 빌드 경고 없애는 방법
11940정성태6/13/20191028개발 환경 구성: 443. Visual Studio의 Connection Manager 기능(Remote SSH 관리)을 위한 명령행 도구파일 다운로드1
11939정성태6/13/20191099오류 유형: 545. Managed Debugging Assistant 'FatalExecutionEngineError'
11938정성태6/12/20191436Math: 59. C# - 웨이트 벡터 갱신식을 이용한 퍼셉트론 분류파일 다운로드1
1  2  3  4  5  6  7  8  9  10  11  12  13  [14]  15  ...