Unicode character lowercase

I am working on a project C++that should receive data from unicode text. I have a problem that I can not omit some unicode character. I use wchar_tto store a unicode character that is read from a unicode file. After that I use _wcslwrto omit the line wchar_t. There are many cases that are not yet lower, for example:

Đ Â Ă Ê Ô Ơ Ư Ấ Ắ Ế Ố Ớ Ứ Ầ Ằ Ề Ồ Ờ Ừ Ậ Ặ Ệ Ộ Ợ Ự

lower case:

đ â ă ê ô ơ ư ấ ắ ế ố ớ ứ ầ ằ ề ồ ờ ừ ậ ặ ệ ộ ợ ự 

I tried tolowerand it still does not work.

+4
source share
1 answer

If you only call tolower, it is called std::tolowerfrom the header clocale, which will toloweronly call the character for ansi.

:

template< class charT >
charT tolower( charT ch, const locale& loc );

2 , :

#include <iostream>
#include <cwctype>
#include <clocale>
#include <algorithm>
#include <locale>

int main() {
    std::setlocale(LC_ALL, "");
    std::wstring data = L"Đ Â Ă Ê Ô Ơ Ư Ấ Ắ Ế Ố Ớ Ứ Ầ Ằ Ề Ồ Ờ Ừ Ậ Ặ Ệ Ộ Ợ Ự";
    std::wcout << data << std::endl;

    // C std::towlower
    for(auto c: data)
    {
        std::wcout << static_cast<wchar_t>(std::towlower(c));
    }
    std::wcout << std::endl;

    // C++ std::tolower(charT, std::locale)
    std::locale loc("");
    for(auto c: data)
    {
        // This is recommended
        std::wcout << std::tolower(c, loc);
    }
    std::wcout << std::endl;
    return 0;
}

:

+2

Source: https://habr.com/ru/post/1621417/


All Articles