Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

영문 설정의 Windows 10 명령행 창(cmd.exe)의 한글 지원

예전에 이와 관련해서 글을 쓴 적이 있는데요.

영문 윈도우에서 C# 콘솔 프로그램의 유니코드 출력 방법
; https://www.sysnet.pe.kr/2/0/1712

cmd.exe 창에서 사용할 폰트를 추가하는 방법
; https://www.sysnet.pe.kr/2/0/1711

개발자 PC 환경 - 유니코드(Unicode)를 위한 설정
; https://www.sysnet.pe.kr/2/0/762

저 때까지만 해도 cmd.exe 창의 폰트 목록이 굉장히 부실했습니다.

시스템 로케일이 영문인 경우:
- Lucida Console
- Consolas 
- Raster Fonts

시스템 로케일이 한글인 경우:
- Raster Fonts
- 굴림체

그래서 영문 윈도우 상에서 한글 출력을 콘솔 프로그램에서 할 수 없었습니다. 그런데, (정확한 버전을 모르겠습니다.) 어느 순간부터 Windows 10의 경우 명령행 창에 "시스템 로케일이 영문"인 경우에도 다음과 같이 풍부한 폰트 목록이 나타났습니다.

[그림 1: 한글 및 다양한 TTF 폰트를 지원]
cmd_support_han_1.png

그래서, 영문 윈도우에서도 (아시아 폰트가 설치되어 있으면) 한글 출력이 얼마든지 가능하게 되었습니다. 실제로 테스트를 해볼까요? ^^

다음과 같이 콘솔 프로그램을 만들고,

using System;

namespace ConsoleApp1
{
    class Program
    {
        static void Main(string[] args)
        {
            System.Text.Encoding oldEncoding = Console.OutputEncoding;

            try
            {
                if (args.Length == 1 && args[0] == "utf8")
                {
                    Console.OutputEncoding = System.Text.Encoding.UTF8;
                }

                Console.WriteLine("한글");
            }
            finally
            {
                Console.OutputEncoding = oldEncoding;
            }
        }
    }
}

"개발자 PC 환경 - 유니코드(Unicode)를 위한 설정" 글에 쓴 대로 "Region and Language" 설정의 비-유니코드 문자열들에 대한 언어설정을 "영어"로 맞춘 윈도우 10에서 실행하면 다음과 같이 나옵니다.

cmd_support_han_2.png

위의 경우는, cmd 창에 한글 폰트를 설정하지 않았기 때문입니다. 따라서 cmd 속성 창에서 "[그림 1: 한글 및 다양한 TTF 폰트를 지원]"과 같이 한글 폰트를 하나 선택하면 다음과 같이 콘솔 화면이 곧바로 한글 출력으로 바뀝니다.

cmd_support_han_3.png

와~~~ 이제야 윈도우가 진정한 다국어를 지원하게 되었습니다. ^^




이와 함께 하나 더 이야기할 것이 있습니다. Windows 10 17134 빌드 버전부터 시스템의 기본 인코딩 설정을 UTF-8로 설정하는 기능이 생겼습니다.

Unicode in Microsoft Windows
; https://en.wikipedia.org/wiki/Unicode_in_Microsoft_Windows

With insider build 17035 and the April 2018 update (nominal build 17134) for Windows 10, a "Beta: Use Unicode UTF-8 for worldwide language support" checkbox appeared for setting the locale code page to UTF-8.


제어판의 Region 창에서 다음과 같이 "Beta: Use Unicode UTF-8 for worldwide language support" 옵션을 체크해 적용할 수 있는데,

cmd_support_han_4.png

이렇게 설정이 되면 윈도우의 기본 코드 페이지가 65001이 됩니다. 따라서 위에서 제작한 콘솔 프로그램의 경우 굳이 코드 페이지를 바꿀 필요가 없이 다음과 같이 간단하게 작성할 수 있습니다.

using System;

namespace ConsoleApp1
{
    class Program
    {
        static void Main(string[] args)
        {
            Console.WriteLine("한글");
        }
    }
}

당연히 위의 프로그램을 실행해도 다음과 같이 정상적으로 한글 출력이 됩니다.

cmd_support_han_5.png

시간은 좀 걸리겠지만, 이제 (CP949로 대표되던 한글) 코드 페이지로 인한 윈도우 응용 프로그램의 호환 문제는 점차로 사라질 듯 싶군요. ^^




참고로, 일단 "Region and Language" 설정의 비-유니코드 문자열들에 대한 언어설정이 "영어"로 설정되면 ("Beta: Use Unicode UTF-8 for worldwide language support" 옵션의 설정과 상관없이) 이후로는 ksc_5601-1987로 저장되어 있던 모든 문서들은 화면에 글자가 깨져 나옵니다. 코드 페이지 값이 명백하게 달라졌으므로!




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

[연관 글]





[최초 등록일: ]
[최종 수정일: 1/27/2020 ]

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

비밀번호

댓글 쓴 사람
 



2018-08-24 12시59분
이 설정을 하면 elasticsearch 실행 시 문제가 발생합니다.

윈도우 환경에서 curl.exe를 이용한 elasticsearch 6.x 기본 사용법
; http://www.sysnet.pe.kr/2/0/11663
정성태
2018-08-24 02시58분
이 설정을 하면 SQL Server 2016 이하 버전 설치 시 오류가 발생할 수 있습니다.

"Use Unicode UTF-8 for worldwide language support" 옵션 설정 시 SQL Server 2016 설치 오류
; http://www.sysnet.pe.kr/2/0/11667
정성태
2018-11-16 03시58분
정성태
2020-10-14 11시54분
"Beta: Use Unicode UTF-8 for worldwide language support" 옵션을 켜면, 기존의 환경에서 ks_c_5601-1987 인코딩 방식으로 저장되어 있던 모든 텍스트 파일의 한글이 깨져서 나옵니다. 이런 경우, 해당 파일의 인코딩을 변경하면 되는데, 가령 iconv.exe 등의 도구를 이용해 다음과 같이 실행해 주면 됩니다.

c:\temp> iconv -f cp949 -t utf-8 test.txt > test_utf8.txt

혹은 편리하게 다음과 같은 식의 배치 파일을 만들어 두시면 좋겠지요. ^^

@echo off

set _filename=%~n1
set _extension=%~x1

"C:\Program Files\Git\usr\bin\iconv.exe" -f cp949 -t utf-8 %1 > "%_filename%_utf8.%_extension%"
정성태

[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
12433정성태11/29/202014Windows: 179. 윈도우 환경에서 클라이언트 소켓의 최대 접속 수 (3) - SO_PORT_SCALABILITY파일 다운로드1
12432정성태11/29/202049Windows: 178. 윈도우 환경에서 클라이언트 소켓의 최대 접속 수 (2) - SO_REUSEADDR [1]파일 다운로드1
12431정성태11/27/202058.NET Framework: 976. UnmanagedCallersOnly + C# 9.0 함수 포인터 사용 시 x86 빌드에서 오동작하는 문제파일 다운로드1
12430정성태11/27/202014오류 유형: 686. Ubuntu - E: The repository 'cdrom://...' does not have a Release file.
12429정성태11/25/202052디버깅 기술: 175. windbg - 특정 Win32 API에서 BP가 안 걸리는 경우
12428정성태11/25/202033VS.NET IDE: 154. Visual Studio - .NET Core App 실행 시 dotnet.exe 실행 화면만 나오는 문제
12427정성태11/25/2020108.NET Framework: 975. .NET Core를 직접 호스팅해 (runtimeconfig.json 없이) EXE만 배포해 실행파일 다운로드1
12426정성태11/24/202024오류 유형: 685. WinDbg Preview - error InitTypeRead
12425정성태11/24/202022VC++: 141. Visual C++ - "Treat Warnings As Errors" 옵션이 꺼져 있는데도 일부 경고가 에러 처리되는 경우
12424정성태11/24/202055VC++: 140. C++의 연산자 동의어(operator synonyms), 대체 토큰
12423정성태11/22/2020101.NET Framework: 974. C# 9.0 - (16) 제약 조건이 없는 형식 매개변수 주석(Unconstrained type parameter annotations)파일 다운로드1
12422정성태11/21/202070.NET Framework: 973. .NET 5, .NET Framework에서만 허용하는 UnmanagedCallersOnly 사용예파일 다운로드1
12421정성태11/23/202073.NET Framework: 972. DNNE가 출력한 NE DLL을 직접 생성하는 방법파일 다운로드1
12420정성태11/19/202034오류 유형: 684. Visual C++ - MSIL .netmodule or module compiled with /GL found; restarting link with /LTCG; add /LTCG to the link command line to improve linker performance
12419정성태11/23/202092VC++: 139. Visual C++ - .NET Core의 nethost.lib와 정적 링크파일 다운로드1
12418정성태11/19/202032오류 유형: 683. Visual C++ - error LNK2038: mismatch detected for 'RuntimeLibrary': value 'MT_StaticRelease' doesn't match value 'MDd_DynamicDebug'파일 다운로드1
12417정성태11/19/202035오류 유형: 682. Visual C++ - warning LNK4099: PDB '...pdb' was not found with '...lib(pch.obj)' or at '...pdb'; linking object as if no debug info
12416정성태11/19/202023오류 유형: 681. Visual C++ - error LNK2001: unresolved external symbol _CrtDbgReport
12415정성태11/19/202081.NET Framework: 971. UnmanagedCallersOnly 특성과 DNNE 사용파일 다운로드1
12414정성태11/20/2020112VC++: 138. x64 빌드에서 extern "C"가 아닌 경우 ___cdecl name mangling 적용 [4]파일 다운로드1
12413정성태11/17/2020115.NET Framework: 970. .NET 5 / .NET Core - UnmanagedCallersOnly 특성을 사용한 함수 내보내기파일 다운로드1
12412정성태11/21/202081.NET Framework: 969. .NET Framework 및 .NET 5 - UnmanagedCallersOnly 특성 사용파일 다운로드1
12411정성태11/12/202071오류 유형: 680. C# 9.0 - Error CS8889 The target runtime doesn't support extensible or runtime-environment default calling conventions.
12410정성태11/12/202096디버깅 기술: 174. windbg - System.TypeLoadException 예외 분석 사례
12409정성태11/12/2020122.NET Framework: 968. C# 9.0의 Function pointer를 이용한 함수 주소 구하는 방법파일 다운로드1
[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...