关于Qt导出CSV中文乱码的问题

在将一个使用Qt5.6在Linux上运行正常的程序移植到Windows(Qt5.14.1)时,遇到中文乱码问题。在main函数中设置UTF-8编码解决了界面显示,但CSV在Office2007 Excel中打开仍乱码。最终通过在导出CSV时指定GBK编码解决了问题,使得程序在Windows环境下和Excel中都能正确显示中文。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题回顾:

在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打开也没问题。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值