问题回顾:
在linux虚拟机有一个程序appA,使用Qt5.6编写的代码。它可以在自己的界面显示操作结果(包含中文),还能把结果导出为csv文件,一切正常。
后来需要windows版的appA,我就把它的源代码都拷贝到主机里(win 10系统),用Qt 5.14.1重新构建的。
当时出现的问题是appA界面里和导出csv文件里的中文都乱码,于是在main函数里加了两行代码:
QTextCodec *codec = QTextCodec::codecForName("UTF-8"); QTextCodec::setCodecForLocale(codec);
输出的中文就正常了。但是测试人员用office2007的excel打开的csv中文乱码,而我用的是wps则没事。
解决过程:
在网上查了很久,有人说excel以ANSI编码打开csv,于是就改了main函数里的编码为:
QTextCodec *codec = QTextCodec::codecForName("ANSI");
QTextCodec::setCodecForLocale(codec);
这下输出的中文和csv里的中文都乱码了。
经过一番折腾,终于改对了,方法如下:
main函数里编码维持utf8不变,在导出csv代码部分设置编码。
我的原来的导出csv部分代码:
QFile file(fileName);
file.open(QIODevice::WriteOnly | QIODevice::Text);
QTextStream out(&file);
out << m_csvStr;
file.close();
现改为:
QFile file(fileName);
file.open(QIODevice::WriteOnly | QIODevice::Text);
QTextCodec *codec = QTextCodec::codecForName("GBK"); //设置为ANSI编码
QTextStream out(&file);
out.setCodec(codec);
out << m_csvStr;
file.close();
再测试就没有问题了,用office 2007 excel打开也没问题。