Как изменить кодировку консоли visual studio
Перейти к содержимому

Как изменить кодировку консоли visual studio

  • автор:

Как изменить кодировку в консоли Visual Studio 2017

Скрин

Сразу хочу оговориться, что меня не интересуют команды типа setlocale(); SetConsoleCP(); и подобные. Если вы хотите предложить вариант как-то связанный с программным исправлением (с добавлением строк кода по исправлению кодировки к каждой программе), пожалуйста, не надо. Меня интересует, как изменить параметр «Текущая кодовая страница», который сейчас выставлен в свойствах консоли на 866 ?
И желательно изменить один раз, чтобы он выставлялся по умолчанию.

Отслеживать
user262779
задан 23 мар 2018 в 0:49
Simon Gerasimenko Simon Gerasimenko
133 1 1 серебряный знак 9 9 бронзовых знаков

Кодовая страница консоли не является свойством Visual Studio. Ее можно изменить на уровне ОС установкой определенных ключей реестра: superuser.com/questions/269818/… (но не нужно, так как неизвестно, что от этого сломается)

23 мар 2018 в 5:08

@MSDN.WhiteKnight В этом вопросе речь о консоли Windows. В консоли windows у меня кодировка 1251. В консоли студии — 866.

23 мар 2018 в 8:32

Никакого понятия «консоль студии» не существует. Решение по ссылке в чистом виде к вам действительно не применимо, оно требует дополнительно в свойствах проекта в разделе отладка установить параметры Команда: c:\windows\system32\cmd.exe и Аргументы: /k $(TargetPath)

23 мар 2018 в 9:08

@MSDN.WhiteKnight Да, теперь моя программа запускается в консоли windows. После завершения программы консоль продолжает работать (ожидает команды), из чего я могу сделать вывод, что для Visual Studio используется нечто другое (вполне вероятно, связанное с консолью windows, т.к. до этого даже значок был другой). Всё таки, можно ли настроить аргументами без команд (чтобы программа открывалась тем, чем открывалась до этого) кодовую страницу этого «нечто другого»?

23 мар 2018 в 9:59
У вас Windows 10?
23 мар 2018 в 10:13

1 ответ 1

Сортировка: Сброс на вариант по умолчанию

На самом деле, кодовая страница для консольных приложений не является настройкой, которую можно изменить через Visual Studio. Дело в том, что не существует никакой «консоли Visual Studio» — при запуске консольного приложения из студии используется самая обычная консоль ОС, та же самая, что и для cmd.exe или любого другого консольного приложения (она может отличаться внешне, в зависимости от настроек, но суть та же). Кодовую страницу для нее можно задать:

  • На уровне ОС, установкой определенных ключей реестра
  • В конкретном сеансе командной оболочки, выполнением команды chcp 1251 . Таким образом, можно изменить действие при запуске приложения (в разделе «Отладка» в свойствах проекта) на c:\windows\system32\cmd.exe /k chcp 1251 && $(TargetPath) для достижения требуемого эффекта. Но тогда отладчик будет отлаживать cmd.exe, а не нашу программу 🙁
  • Для конкретного консольного приложения через параметр реестра HKCU\Console\(путь к приложению)\CodePage (REG_DWORD).

Используя последний способ и шаблоны проектов, можно автоматизировать установку кодовой страницы для приложений, собираемых в студии.

    Создадим bat-файл следующего содержания:

set MYSTRING=%~1 reg add "HKCU\Console\%MYSTRING:\=_%" /v CodePage /t REG_DWORD /f /d 1251 

Поместим его, допустим, в папку c:\scripts\codepage.bat

  1. Создадим проект консольного приложения под шаблон, допустим Cp1251ConsoleApplication
  2. В свойствах проекта, в разделе События построения — Событие после построения, введем в параметр Командная строка значение:

c:\scripts\codepage.bat "$(TargetPath)" 

Теперь при создании нового проекта в в разделе Visual C++ появится шаблон Cp1251ConsoleApplication. Если создавать проект на его основе, при сборке проекта в реестре автоматически будет устанавливаться кодовая страница консоли для этого приложения. Недостаток способа в том, что этот раздел реестра будет замусориваться, если создавать много проектов.

Также, при задействовании команды Запуск без отладки способ не сработает: вместо вашего приложения будет запускаться cmd.exe; для него кодовая страница настраивается отдельно — созданием точно такой же ветки в реестре с путем к cmd.exe.

Гарантированная локализация/русификация консоли Windows

Консольные приложения до сих пор остаются наиболее востребованным видом приложений, большинство разработчиков оттачивают архитектуру и бизнес-логику именно в консоли. При этом они нередко сталкиваются с проблемой локализации — русский текст, который вполне адекватно отражается в исходном файле, при выводе на консоль приобретает вид т.н. «кракозябр».

В целом, локализация консоли Windows при наличии соответствующего языкового пакета не представляется сложной. Тем не менее, полное и однозначное решение этой проблемы, в сущности, до сих пор не найдено. Причина этого, главным образом, кроется в самой природе консоли, которая, являясь компонентом системы, реализованным статическим классом System.Console, предоставляет свои методы приложению через системные программы-оболочки, такие как командная строка или командный процессор (cmd.exe), PowerShell, Terminal и другие.
По сути, консоль находится под двойным управлением — приложения и оболочки, что является потенциально конфликтной ситуацией, в первую очередь в части использования кодировок.

Данный материал не предлагает строгий алгоритм действий, а направлен на описание узловых проблем, с которыми неизбежно сталкивается разработчик локализованного консольного приложения, а также некоторые возможные пути их разрешения. Предполагается, что это позволит разработчику сформировать стратегию работы с локализованной консолью и эффективно реализовать существующие технические возможности, большая часть которых хорошо описана и здесь опущена.

Виды консолей

В общем случае функции консоли таковы:

  • управление операционной системой и системным окружением приложений на основе применения стандартных системных устройств ввода-вывода (экран и клавиатура), использования команд операционной системы и/или собственно консоли;
  • запуск приложений и обеспечение их доступа к стандартным потокам ввода-вывода системы, также с помощью стандартных системных устройств ввода-вывода.

Основная консоль Windows — командная строка или иначе командный процессор ( CMD ). Большие возможности предоставляют оболочки PowerShell ( PS ), Windows PowerShell ( WPS ) и Terminal. По умолчанию Windows устанавливает Windows Power Shell мажорной версией до 5, однако предлагает перейти на новую версию — 7-ку, имеющую принципиальное отличие (вероятно, начинающееся с 6-ки) — кроссплатформенность. Terminal — также отдельно уставливаемое приложение, по сути интегратор всех ранее установленных оболочек PowerShell и командной строки.

Отдельным видом консоли можно считать консоль отладки Visual Studio ( CMD-D ).

Конфликт кодировок

Полностью локализованная консоль в идеале должна поддерживать все мыслимые и немыслимые кодировки приложений, включая свои собственные команды и команды Windows, меняя «на лету» кодовые страницы потоков ввода и вывода. Задача нетривиальная, а иногда и невозможная — кодовые страницы DOS (CP437, CP866) плохо совмещаются с кодовыми страницами Windows и Unicode.

Исторически кодовой страницей Windows является CP1251 (Windows-1251, ANSI, Windows-Cyr), уверенно вытесняемая 8-битной кодировкой Юникода CP65001 (UTF-8, Unicode Transformation Format), в которой выполняется большинство современных приложений, особенно кроссплатформенных. Между тем, в целях совместимости с устаревшими файловыми системами, именно в консоли Windows сохраняет базовые кодировки DOS — CP437 (DOSLatinUS, OEM) и русифицированную CP866 (AltDOS, OEM).

Совет 1. Выполнять разработку текстовых файлов (программных кодов, текстовых данных и др.) исключительно в кодировке UTF-8. Мир любит Юникод, а кроссплатформенность без него вообще невозможна.

Совет 2. Периодически проверять кодировку, например в текстовом редакторе Notepad++. Visual Studio может сбивать кодировку, особенно при редактировании за пределами VS.

Поскольку в консоли постоянно происходит передача управления от приложений к собственно командному процессору и обратно, регулярно возникает «конфликт кодировок», наглядно иллюстрируемый таблица 1 и 2, сформированных следующим образом:

Были запущены три консоли — CMD , PS и WPS . В каждой консоли менялась кодовая страница с помощью команды CHCP, выполнялась команда Echo c двуязычной строкой в качестве параметра (табл. 1), а затем в консоли запускалось тестовое приложение, исходные файлы которого были созданы в кодировке UTF-8 (CP65001): первая строка формируется и направляется в поток главным модулем, вторая вызывается им же, формируется в подключаемой библиотеке классов и направляется в поток опять главным модулем, третья строка полностью формируется и направляется в поток подключаемой библиотекой.

Команды и код приложения под катом

  • > Echo ffffff фффффф // в командной строке
  • PS> Echo ffffff фффффф // в PowerShell
  • PS> Echo ffffff . // так выглядит та же команда в Windows PowerShell

код тестового приложения:

using System; using ova.common.logging.LogConsole; using Microsoft.Extensions.Logging; using ova.common.logging.LogConsole.Colors; namespace LoggingConsole.Test < partial class Program < static void Main2(string[] args) < ColorLevels.ColorsDictionaryCreate(); Console.WriteLine("Hello World! Привет, мир!"); //вывод строки приветствия на двух языках LogConsole.Write("Лог из стартового проекта", LogLevel.Information); Console.WriteLine($"8. Active codepage: input , output "); Console.ReadKey(); > > >

Командную часть задания все консоли локализовали практически без сбоев во всех кодировках, за исключением: в WPS неверно отображена русскоязычная часть команды во всех кодировках.

Табл. 1. Результат выполнения команды консоли Echo ffffff фффффф

Вывод тестового приложения локализован лишь в 50% испытаний, как показано в табл.2.

Табл. 2. Результат запуска приложения LoggingConsole.Test

Сoвет 3. Про PowerShell забываем раз и навсегда. Ну может не навсегда, а до следующей мажорной версии.

По умолчанию Windows устанавливает для консоли кодовые страницы DOS. Чаще всего CP437, иногда CP866. Актуальные версии командной строки cmd.exe способны локализовать приложения на основе русифицированной кодовой страницы 866, но не 437, отсюда и изначальный конфликт кодировок консоли и приложения. Поэтому

Совет 4. Перед запуском приложения необходимо проверить кодовую страницу консоли командой CHCP и ей же изменить кодировку на совместимую — 866, 1251, 65001.

Совет 5. Можно установить кодовую страницу консоли по умолчанию. Кратко: в разделе реестра \HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Command Processor добавить или изменить значение параметра Autorun на: chcp . Очень подробно здесь: Изменить кодовую страницу консоли Windows по умолчанию на UTF-8 (qastack.ru), оригинал на английском здесь: Change default code page of Windows console to UTF-8.

Проблемы консолей Visual Studio

В Visual Studio имеется возможность подключения консолей, по умолчанию подключены командная строка для разработчика и Windows PowerShell для разработчика. К достоинствам можно отнести возможности определения собственных параметров консоли, отдельных от общесистемных, а также запуск консоли непосредственно в директории разработки. В остальном — это обычные стандартные консоли Windows, включая, как показано ранее, установленную кодовую страницу по умолчанию.

Отдельной опцией Visual Studio является встроенная односеансная консоль отладки, которая перехватывает команду Visual Studio на запуск приложения, запускается сама, ожидает компиляцию приложения, запускает его и отдает ему управление. Таким образом, отладочная консоль в течение всего рабочего сеанса находится под управлением приложения и возможность использования команд Windows или самой консоли, включая команду CHCP, не предусмотрена. Более того, отладочная консоль не воспринимает кодовую страницу по умолчанию, определенную в реестре, и всегда запускается в кодировке 437 или 866.

Совет 6. Тестирование приложения целесообразно выполнять во внешних консолях, более дружелюбных к локализации.

Анализ проблем консолей был бы не полон без ответа на вопрос — можно ли запустить консольное приложение без консоли? Можно — любой файл «.exe» запустится двойным кликом, и даже откроется окно приложения. Однако консольное приложение, по крайней мере однопоточное, по двойному клику запустится, но консольный режим не поддержит — все консольные вводы-выводы будут проигнорированы, и приложение завершится

Локализация отладочной консоли Visual Studio

Отладочная консоль — наиболее востребованная консоль разработчика, гораздо более удобная, чем внешняя консоль, поэтому резонно приложить максимум усилий для ее локализации.

На самом деле, правильнее говорить о локализации приложения в консоли — это важное уточнение. Microsoft по этому поводу высказывается недвусмысленно: «Programs that you start after you assign a new code page use the new code page. However, programs (except Cmd.exe) that you started before assigning the new code page will continue to use the original code page». Иными словами, консоль можно локализовать когда угодно и как угодно, но приложение будет локализовано в момент стабилизации взаимодействия с консолью в соответствии с текущей локализацией консоли, и эта локализация сохранится до завершения работы приложения. В связи с этим возникает вопрос — в какой момент окончательно устанавливается связь консоли и приложения?

Важно! Приложение окончательно стабилизирует взаимодействие с консолью в момент начала ввода-вывода в консоль, благодаря чему и появляется возможность программного управления локализацией приложения в консоли — до первого оператора ввода-вывода.

Ниже приведен пример вывода тестового приложения в консоль, иллюстрирующий изложенное. Метод Write получает номера текущих страниц, устанавливает новые кодовые страницы вводного и выводного потоков, выполняет чтение с консоли и записывает выводную строку, содержащий русский текст, в том числе считанный с консоли, обратно в консоль. Операция повторяется несколько раз для всех основных кодовых страниц, упомянутых ранее.

F:\LoggingConsole.Test\bin\Release\net5.0>chcp Active code page: 1251 F:\LoggingConsole.Test\bin\Release\net5.0>loggingconsole.test Codepages: current 1251:1251, setted 437:437, ΓΓεΣΦ∞ 5 ±Φ∞ΓεδεΓ ∩ε-≡≤±±ΩΦ: Θ÷≤Ωσ=Θ÷≤Ωσ Codepages: current 437:437, setted 65001:65001, 5 -: = Codepages: current 65001:65001, setted 1252:1252, ââîäèì 5 ñèìâîëîâ ïî-ðóññêè: éöóêå=éöóêå Codepages: current 1252:1252, setted 1251:1251, вводим 5 символов по-русски: йцуке=йцуке Codepages: current 1251:1251, setted 866:866, ттюфшь 5 ёшьтюыют яю-Ёєёёъш: щЎєъх=щЎєъх Codepages: current 866:866, setted 1251:1251, вводим 5 символов по-русски: йцуке=йцуке Codepages: current 1251:1251, setted 1252:1252, ââîäèì 5 ñèìâîëîâ ïî-ðóññêè: éöóêå=éöóêå F:\LoggingConsole.Test\bin\Release\net5.0>chcp Active code page: 1252
  • приложение запущено в консоли с кодовыми страницами 1251 (строка 2);
  • приложение меняет кодовые страницы консоли (current, setted);
  • приложение остановлено в консоли с кодовыми страницами 1252 (строка 11, setted);
  • по окончании работы приложения изменения консоли сохраняются (строка 14 — Active codepage 1252);
  • Приложение адекватно локализовано только в случае совпадения текущих кодовых страниц консоли (setted 1251:1251) с начальными кодовыми страницами (строки 8 и 10).
using System; using System.Runtime.InteropServices; namespace LoggingConsole.Test < partial class Program < [DllImport("kernel32.dll")] static extern uint GetConsoleCP(); [DllImport("kernel32.dll")] static extern bool SetConsoleCP(uint pagenum); [DllImport("kernel32.dll")] static extern uint GetConsoleOutputCP(); [DllImport("kernel32.dll")] static extern bool SetConsoleOutputCP(uint pagenum); static void Main(string[] args) < Write(437); Write(65001); Write(1252); Write(1251); Write(866); Write(1251); Write(1252); >static internal void Write(uint WantedIn, uint WantedOut) < uint CurrentIn = GetConsoleCP(); uint CurrentOut = GetConsoleOutputCP(); Console.Write($"current : - текущая кодировка, "); /*wanted :,*/ SetConsoleCP(WantedIn); SetConsoleOutputCP(WantedOut); Console.Write($"setted : - новая кодировка, "); Console.Write($"вводим 3 символа по-русски: "); string str = "" + Console.ReadKey().KeyChar.ToString(); str += Console.ReadKey().KeyChar.ToString(); str += Console.ReadKey().KeyChar.ToString(); Console.WriteLine($"="); > static internal void Write(uint ChangeTo) < Write(ChangeTo, ChangeTo); >> > 

Программное управление кодировками консоли — это единственный способ гарантированной адекватной локализацией приложения в консоли. Языки .Net такой возможности не предоставляют, однако предоставляют функции WinAPI: SetConsoleCP(uint numcp) и SetConsoleOutputCP(uint numcp), где numcp — номер кодовой страницы потоков ввода и вывода соответственно. Подробнее здесь: Console Functions — Windows Console | Microsoft Docs. Пример применения консольных функций WInAPI можно посмотреть в тестовом приложении под катом выше.

Совет 7. Обязательный и повторный! Функции SetConsoleCP должны размещаться в коде до первого оператора ввода-вывода в консоль.

Стратегия локализации приложения в консоли

  1. Удалить приложение PowerShell (если установлено), сохранив Windows PowerShell;
  2. Установить в качестве кодовую страницу консоли по умолчанию CP65001 (utf-8 Unicode) или CP1251 (Windows-1251-Cyr), см. совет 5;
  3. Разработку приложений выполнять в кодировке utf-8 Unicode;
  4. Контролировать кодировку файлов исходных кодов, текстовых файлов данных, например с помощью Notepad++;
  5. Реализовать программное управление локализацией приложения в консоли, пример ниже под катом:
using System; using System.Runtime.InteropServices; namespace LoggingConsole.Test < partial class Program < static void Main(string[] args) < [DllImport("kernel32.dll")] static extern bool SetConsoleCP(uint pagenum); [DllImport("kernel32.dll")] static extern bool SetConsoleOutputCP(uint pagenum); SetConsoleCP(65001); //установка кодовой страницы utf-8 (Unicode) для вводного потока SetConsoleOutputCP(65001); //установка кодовой страницы utf-8 (Unicode) для выводного потока Console.WriteLine($"Hello, World!"); >> > 

Программирование на C, C# и Java

Уроки программирования, алгоритмы, статьи, исходники, примеры программ и полезные советы

ОСТОРОЖНО МОШЕННИКИ! В последнее время в социальных сетях участились случаи предложения помощи в написании программ от лиц, прикрывающихся сайтом vscode.ru. Мы никогда не пишем первыми и не размещаем никакие материалы в посторонних группах ВК. Для связи с нами используйте исключительно эти контакты: vscoderu@yandex.ru, https://vk.com/vscode

Проблемы с кодировкой кириллицы в консоли. Смена кодировки

Зачастую у программистов появляются проблемы с русским языком в консоли при загрузке в неё текстового файла — вместо кириллицы появляются какие-то непонятные символы или вопросительные знаки. Данная проблема очень легко решается — нужно просто сменить кодировку файла на UTF-8 или на Юникод (либо на какую-либо другую, с которой консоль заработает). Как это сделать, вы узнаете в нашей статье. Итак, если у вас в консоли вместо кириллицы написано что-то похожее на символы с нижнего изображения, либо просто непонятный набор неизвестных символов, то всё дело в неправильной кодировке файла.

Проблемы с кодировкой кириллицы в консоли. Смена кодировки - vscode.ru

Исправить данную проблему не составит труда.

Проблемы с кодировкой кириллицы в блокноте

У каждого на компьютере имеется блокнот — самый простой помощник в данной проблеме. Всё, что нам надо — это открыть «сломанный» файл в блокноте (главное, чтобы в нём русский язык отображался правильно, иначе придётся заново переписывать текст), затем нажать в блокноте вкладку «Файл», а затем «Сохранить как…». В низу появившегося окна можно будет найти надпись «Кодировка» с комбобоксом, в котором Вам надо выбрать UTF-8 либо Юникод (это почти одинаковые кодировки, но если одна из них не заработает, то выбирайте вторую).

Проблемы с кодировкой кириллицы в консоли. Смена кодировки - vscode.ru

После сохранения файла попробуйте запустить консоль ещё раз, всё должно заработать.

Проблемы с кодировкой кириллицы в WordPad

Текстовым редактором WordPad также можно починить файл. Делается это идентично способу с блокнотом. Опять надо файл «Сохранить как…», однако выбор кодировки здесь не задан отдельно, как в блокноте, а вынесен в «Тип файла».

Нам нужно выбрать тип «Текстовый документ в Юникоде» и таким образом сохранить файл.

Проблемы с кодировкой кириллицы в консоли. Смена кодировки - vscode.ru

Проблемы с кодировкой кириллицы в Visual Studio

Вариант 1. Изменение кодировки файла.

Если ваш файл открыт у вас в Visual Studio, то для смены кодировки нужно выполнить следующие действия: В рабочей среде кликнуть на вкладке файла:

Проблемы с кодировкой кириллицы в консоли. Смена кодировки - vscode.ru

Затем перейди в меню «Файл» -> «Дополнительные параметры сохранения..».

Проблемы с кодировкой кириллицы в консоли. Смена кодировки - vscode.ru

В появившемся окне смотрим огромный список с названием «Кодировка» и выбираем там Юникод:

Проблемы с кодировкой кириллицы в консоли. Смена кодировки - vscode.ru

После нажимаем «ОК», и всё готово!

Вариант 2. Изменение кодировки программно.

Кроме того, в Visual Studio можно легко поменять кодировку файла в самом коде. Делается это, на примере работы с классом StreamReader, вот так:

[VS] Кодировка диспетчера пакетов nuget

Результат вывода команды dotnet в консоли диспетчера пакетов nuget отображается в неверной кодировке (ansi вместо utf8) при использовании на системе с русской локализацией. Как через настройки Visual Studio исправить отображение этой кодировки?

ChatGPT
Языковая модель

Сообщения 1,336 Реакции 58

Результат вывода команды dotnet в консоли диспетчера пакетов nuget отображается в неверной кодировке (ansi вместо utf8) при использовании на системе с русской локализацией. Как через настройки Visual Studio исправить отображение этой кодировки?

Вы можете изменить кодировку консоли диспетчера пакетов NuGet в Visual Studio, следуя этим шагам:

1. Откройте Visual Studio и перейдите в меню «Tools» (Инструменты).
2. Выберите «Options» (Опции).
3. Разверните раздел «Environment» (Среда).
4. Выберите «Output Window» (Окно вывода).
5. В выпадающем списке «Show output from» (Показывать вывод из) выберите «Package Manager» (Диспетчер пакетов).
6. В поле «Encoding» (Кодировка) выберите «Unicode (UTF-8 with signature) — Codepage 65001» (Юникод (UTF-8 с сигнатурой) — Кодовая страница 65001).
7. Нажмите «OK» (ОК), чтобы сохранить изменения.

Теперь кодировка консоли диспетчера пакетов NuGet должна отображаться правильно. Если проблема не решена, попробуйте перезапустить Visual Studio и выполнить команду dotnet снова.

Dragokas
Angry & Scary Developer

Команда форума
Супер-Модератор
Разработчик
Клуб переводчиков
Сообщения 7,476 Реакции 6,366
Не нашел такой опции.
Правильный ответ здесь: C++ Visual Studio character encoding issues

ChatGPT
Языковая модель

Сообщения 1,336 Реакции 58
Не нашел такой опции.
Правильный ответ здесь: C++ Visual Studio character encoding issues

Приношу свои извинения за предыдущий неправильный ответ. Действительно, для изменения кодировки консоли диспетчера пакетов NuGet в Visual Studio необходимо изменить настройки консоли в Visual Studio. Спасибо за исправление.

Вот шаги, которые необходимо выполнить:

1. Откройте консоль диспетчера пакетов NuGet в Visual Studio.
2. Нажмите правой кнопкой мыши на заголовке консоли и выберите «Properties» (Свойства).
3. В разделе «Options» (Опции) выберите «Font» (Шрифт) и измените его на «Lucida Console».
4. В разделе «Options» (Опции) выберите «Layout» (Макет) и измените «Screen buffer size» (Размер буфера экрана) на «Width: 120» (Ширина: 120) и «Height: 9999» (Высота: 9999).
5. В разделе «Options» (Опции) выберите «Terminal» (Терминал) и измените «Character set» (Набор символов) на «UTF-8».

После выполнения этих шагов кодировка консоли диспетчера пакетов NuGet должна отображаться правильно. Если проблема не решена, попробуйте перезапустить Visual Studio и выполнить команду dotnet снова.

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *