QLocale 类在各种语言的数字及其字符串表示之间进行转换。
QLocale 在其构造函数中使用语言/国家对进行初始化,并提供类似于 QString 中的数字到字符串和字符串到数字的转换功能。
QLocale 支持默认语言环境的概念,该概念由应用程序启动时系统的语言环境设置确定。 可以通过调用静态成员 setDefault() 来更改默认语言环境。 设置默认语言环境有以下效果:
- 如果 QLocale 对象是用默认构造函数构造的,它将使用默认语言环境的设置。
- QString::toInt()、QString::toDouble()等,根据默认locale解释字符串。 如果失败,则返回到“C”语言环境。
- 当格式字符串中的位置说明符包含“L”时,QString::arg() 使用默认语言环境来格式化数字,例如 “%L1”。
QLocale(const QString &name)
构造具有指定名称的 QLocale 对象,其格式为“language[_script][_country][.codeset][@modifier]”或“C”,其中:
- language 是一个小写的两个字母的 ISO 639 语言代码(还有一些三个字母的代码),
- 脚本是一个标题,四字母,ISO 15924 脚本代码,
- country 是一个大写的两个字母的 ISO 3166 国家代码(也是联合国定义的“419”),
- 并且代码集和修饰符被忽略。
//第一种用法:默认构造 获取本地的设置
qDebug() << QString::fromLocal8Bit("第一种用法:默认构造 获取本地的设置");
QLocale locale1;
qDebug() << locale1.country();
qDebug() << locale1.language();
qDebug() << locale1;
qDebug() << locale1.toString(QDateTime::currentDateTime()) << endl;
//第二种方法:
qDebug() << QString::fromLocal8Bit("第二种用法:");
QLocale locale2(QLocale::Chinese, QLocale::China);//en_US
qDebug() << locale2.country();
qDebug() << locale2.language();
qDebug() << locale2;
qDebug() << locale2.toString(QDateTime::currentDateTime()) << endl;
//第三种方法:
qDebug() << QString::fromLocal8Bit("第三种方法:");
QLocale locale3("zh_CN");//en_US
qDebug() << locale3.country();
qDebug() << locale3.language();
qDebug() << locale3;
qDebug() << locale3.toString(QDateTime::currentDateTime()) << endl;
//第四种方法:
qDebug() << QString::fromLocal8Bit("第四种方法:");
QLocale locale4 = QLocale::system();
qDebug() << locale4.country();
qDebug() << locale4.language();
qDebug() << locale4;
qDebug() << locale4.toString(QDateTime::currentDateTime()) << endl;
//第五种方法:
qDebug() << QString::fromLocal8Bit("第五种方法:");
QLocale locale5 = QLocale::c();
qDebug() << locale5.country();
qDebug() << locale5.language();
qDebug() << locale5;
qDebug() << locale5.toString(QDateTime::currentDateTime()) << endl;
运行结果: