Как расшифровать кириллику от CP1251 до UTF8 и распечатать его с помощью Ncursers?C++

Программы на C++. Форум разработчиков
Ответить
Anonymous
 Как расшифровать кириллику от CP1251 до UTF8 и распечатать его с помощью Ncursers?

Сообщение 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

Подробнее здесь: https://stackoverflow.com/questions/797 ... g-ncursers
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C++»