У меня есть данные, которые первоначально хранятся в кодировании CP1251, но производственная машина находится в кодировании UTF8, мне нужно вывести данные, используя NCURSERS в консоли.
Данные выводятся в виде таблицы, но столбцы сдвинуты, что не должно быть. Значение как строка усечено, чтобы соответствовать размеру имени столбца. < /P>
Пример: < /p>
column name = name < /p>
Значение столбца = anddreй < /p>
Похоже: < /p>
| name |
| Андр |
< /code>
должно быть: < /p>
| Col name |
| Col Андр |
Я уже использую библиотеку -lncurserw , используйте setlocale (lc_all, ""); перед началом ncursers
my output:
int iAdditionSpaces = countCyrillicInCP1251(vRow[j]);
std::string sOut;
int iSumSize = static_cast(sztWidthColHeader) + iAdditionSpaces;
sOut = boost::locale::conv::between( vRow[j].substr(0, static_cast(sztWidthColHeader))
, "UTF-8"
, "Windows-1251")
.substr(0, iSumSize);
if (static_cast(sztWidthColHeader) > iAdditionSpaces)
{
printw( u8" %-*s "
, static_cast(sztWidthColHeader) + iAdditionSpaces
, sOut.c_str());
}
else
{
printw( u8" %-*s "
, static_cast(sztWidthColHeader)
, sOut.c_str());
}
< /code>
Метод подсчета кириллических символов: < /p>
size_t CMuncTable::countCyrillicInCP1251(const std::string& sCp1251)
{
size_t count = 0;
for (unsigned char c : sCp1251)
{
if ((c >= 0xC0 && c
Подробнее здесь: https://stackoverflow.com/questions/797 ... g-ncursers
Как расшифровать кириллику от CP1251 до UTF8 и распечатать его с помощью Ncursers? ⇐ C++
Программы на C++. Форум разработчиков
1757942595
Anonymous
У меня есть данные, которые первоначально хранятся в кодировании CP1251, но производственная машина находится в кодировании UTF8, мне нужно вывести данные, используя NCURSERS в консоли.
Данные выводятся в виде таблицы, но столбцы сдвинуты, что не должно быть. Значение как строка усечено, чтобы соответствовать размеру имени столбца. < /P>
Пример: < /p>
column name = name < /p>
Значение столбца = anddreй < /p>
Похоже: < /p>
| name |
| Андр |
< /code>
должно быть: < /p>
| Col name |
| Col Андр |
Я уже использую библиотеку -lncurserw , используйте setlocale (lc_all, ""); перед началом ncursers
my output:
int iAdditionSpaces = countCyrillicInCP1251(vRow[j]);
std::string sOut;
int iSumSize = static_cast(sztWidthColHeader) + iAdditionSpaces;
sOut = boost::locale::conv::between( vRow[j].substr(0, static_cast(sztWidthColHeader))
, "UTF-8"
, "Windows-1251")
.substr(0, iSumSize);
if (static_cast(sztWidthColHeader) > iAdditionSpaces)
{
printw( u8" %-*s "
, static_cast(sztWidthColHeader) + iAdditionSpaces
, sOut.c_str());
}
else
{
printw( u8" %-*s "
, static_cast(sztWidthColHeader)
, sOut.c_str());
}
< /code>
Метод подсчета кириллических символов: < /p>
size_t CMuncTable::countCyrillicInCP1251(const std::string& sCp1251)
{
size_t count = 0;
for (unsigned char c : sCp1251)
{
if ((c >= 0xC0 && c
Подробнее здесь: [url]https://stackoverflow.com/questions/79765193/how-to-decode-cyrillic-from-cp1251-to-utf8-and-print-it-using-ncursers[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия