2.3. QString使用arg(int, int, int) 格式化
原型【1】为:
QString QString::arg(int a, int fieldWidth = 0, int base = 10, QChar fillChar = QLatin1Char( ' ' )) const
- a:表示要处理的数字;
- fieldWidth:字宽;
- base:数字基数;
- fillChar为当设置了fieldWidth之后,自动补齐的字符
示例如下:
str = QString("十进制 63 的十进制为 %1").arg(63, 0, 10);
//输出:"十进制 63 的十进制为 63"
str = QString("十进制 63 的十六进制为 %1").arg(63, 0, 16);
//输出:"十进制 63 的十六进制为 3f"
str = QString("%1 %L2 %L3").arg(12345)
.arg(1987654321) //根据结果,可知道这个L的作用
.arg(12345, 0, 8); //但使用这种方式时,L失效
//输出为:12345 1,987,654,321 30071
//这里%L3的L没有任何作用
2.4. 使用arg(double, double, double)
在原型【1】中的a的类型还可以是uint、long、double、udouble等数字的类型!
这里当a的类型为double时,原型为:
QString QString::arg(double a, int fieldWidth = 0, char format = 'g', int precision = -1, QChar fillChar = QLatin1Char( ' ' )) const
- format和precision,一个指明规格,一个指明精度。
- 规格默认为 ‘g’ 或 ‘G’,指示后面的精度为整数和小数部分总和的长度;
- 规格为’e’或 ‘E’ 时,表示为科学记数法形式,精度部分指示的为小数部分的位数长度;
- 规格为其他字符时,无作用,输出原double数字。
示例如下:
double d = 12.345689;
str = QString("delta: %1").arg(d, 0, 'g',4);
//输出为:"delta: 12.35" ---这里进行了四舍五入
str = QString("delta: %1").arg(d, 0, 'G',5);
//输出为:"delta: 12.346" ---这里进行了四舍五入
str = QString("delta: %1").arg(d, 0, 'e',4);
//输出为:"delta: 1.234e+01"
str = QString("delta: %1").arg(d, 0, 'E',4);
//输出为:"delta: 1.234E+01"
str = QString("delta: %1").arg(d, 0, 'r',4);
//输出为:"delta: 12.345689"
str = QString("delta: %1").arg(d, 0, 'Q',4);
//输出为:"delta: 12.345689"
2.5. 项目代码示例
myLogInstance2.LogDebug("%s()[%d] const std::pair<int,int> &v: i = %d, iStr = %s", __FUNCTION__, __LINE__, i,
(char *)(QString("%1").arg(i, 3 ,10, QChar('0'))).toUtf8().constData());