写入csv里面包含, " 的情况处理

本文记录了在实现网页导出功能过程中遇到的CSV文件乱码、字段分割及特殊字符处理等问题,并分享了使用Python的csv和stringIO模块解决这些问题的具体步骤。

因为一个网页导出功能,这里已经反复让我提交了三次hotfix…确实与我自身有问题。很有必要整理一下。

第一次提交hotfix:
导出的时候会出现乱码,就进行一个转码encoding gb2312即可。
第二次提交hotfix:
csv是用英文的逗号来分割字段的,而如果字段里面包含英文逗号怎么办?就需要把这个字段两端用双引号引起来!
第三次提交hotfix:
很久都没有报错。但是没料到,有的名字字段里面有人用的是引号,然后数据就又出问题了。
我这个时候其实已经很无语了,只能说我的技术太渣。。。但是还是得解决。如果名字里面有“ 就再加一个,变成”“ 就可以了。

但是这次我没有这么做。因为老大告诉我了csv和stringIO的方法。

因为有一个模块叫做csv. csv里面创建一个writer对象之后有writerrow的方法。但是我查阅到的都是采用创建一个csv文件的方式。而根据我这里的业务需求是不需要创建文件的,这里直接用stringIO即可。但是csv这里还会引起一个报错问题,在python2下,需要通过sys.setdefaultencoding(“utf8”)来设置一下默认编码。


这里简单列下python的实现。

import sys
import StringIO
reload(sys)
sys.setdefaultencoding('utf8')
stream = StringIO.StringIO()
import csv
writer = csv.writer(stream)
search_data = [{'user_id': 10041L, 'name': u'\u65fa\u5f69a2acd7'},
               {'user_id': 10041L, 'name': u'\u65fa\u5f69a2acd7'}]
stream = StringIO.StringIO()
writer = csv.writer(stream)
for info in search_data:
    writer.writerow([[info["user_id"], info['name']])

print stream.getvalue()

参考:

http://blog.youkuaiyun.com/paul342/article/details/22800137
https://www.cnblogs.com/mayi0312/p/6840931.html
https://docs.python.org/2/library/csv.html#writer-objects

<think>嗯,用户的问题是关于在Qt中将数据写入CSV文件,并且保留两位小数。我需要先理解用户的需求,然后根据提供的引用内容来找到解决方案。 首先,用户提到使用Qt编写程序,所以需要Qt相关的代码示例。他们希望将数据写入CSV文件,并且数值需要保留两位小数。CSV文件本质上是文本文件,数值的格式化应该在写入之前处理。 查看引用[1],里面有一个Qt写入CSV的示例,使用了QFile和QIODevice,用write方法写入字符串。这里的关键是将数值转换为字符串时保留两位小数。在C++中,可以使用QString的arg方法,设置格式为%.2f,这样就能保留两位小数了。 引用[3]中的Python示例展示了如何用csv模块处理数据,但用户需要的是Qt的C++代码,所以主要参考引用[1]。用户可能需要处理不同的数据类型,比如整数和浮点数,但重点是浮点数的格式化。 步骤应该是这样的:打开文件,写入表头,然后逐行写入数据。对于每个数值,使用QString::number(value, 'f', 2)来格式化为两位小数。例如,将123.456转换为"123.46"。 需要注意的是,CSV文件中的数值不需要额外的引号,直接以字符串形式写入即可。另外,确保文件以正确的模式打开,比如QIODevice::WriteOnly或QIODevice::Append,并且在写入后关闭文件。 可能还需要处理本地化问题,比如小数点符号是否使用点号,但通常Qt的QString::number会使用系统设置,不过为了确保CSV的兼容性,可能需要强制使用点号作为小数分隔符。 另外,用户可能没有提到如何处理整数,但示例中可以统一使用两位小数,或者根据数据类型判断。但根据用户需求,只需处理浮点数的两位小数,其他类型可以原样写入。 总结一下,代码示例应该包括打开文件,格式化和写入数据,使用QString的格式化功能来保留两位小数。同时,检查文件是否成功打开,写入是否成功,这些都是必要的错误处理步骤。</think>在Qt中实现CSV文件写入并保留两位小数的示例代码: ```cpp #include <QFile> #include <QTextStream> void writeToCSV() { QFile file("data.csv"); if (!file.open(QIODevice::WriteOnly | QIODevice::Text)) { qDebug() << "文件打开失败"; return; } QTextStream out(&file); // 写入表头 out << "ID,温度(℃),电压(V),转速(rpm)\n"; // 示例数据 int id = 1; double temperature = 25.3678; float voltage = 12.5; double rotation = 1500.0; // 格式化写入(保留两位小数) out << id << "," << QString::number(temperature, 'f', 2) << "," << QString::number(voltage, 'f', 2) << "," << QString::number(rotation, 'f', 2) << "\n"; // 写入第二行数据示例 out << 2 << "," << QString::number(32.1415, 'f', 2) << "," << QString::number(24.999, 'f', 2) << "," << QString::number(1800.4567, 'f', 2) << "\n"; file.close(); qDebug() << "数据写入完成"; } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值