首先使用fstream逐行读取CSV文件,再通过stringstream按逗号分割字段,将数据存储于二维字符串向量中;为处理引号和空格,引入trim函数清理首尾空白与引号;对于数值转换,采用std::stod或std::stoi并结合异常处理确保健壮性;针对含逗号的字段被引号包围的情况,简单方法难以准确解析,需状态机或专用库支持;最终示例展示读取并打印全部内容的基本流程,适用于简单场景,复杂情况推荐使用fast-cpp-csv-parser等成熟库。

读取CSV文件在C++中没有内置支持,需要手动解析。CSV文件通常以逗号分隔字段,每行代表一条记录。实现时需考虑换行、空格、引号包裹的字段等常见情况。下面介绍一种简单而实用的方法来读取和解析CSV数据。
使用fstream读取CSV文件
通过std::ifstream打开并逐行读取CSV文件。每一行用std::getline获取,再按逗号拆分字段。
示例代码:
#include #include #include #include #includestd::vector<std::vector> readCSV(const std::string& filename) {std::vector<std::vector> data;std::ifstream file(filename);std::string line;
while (std::getline(file, line)) { std::vector row; std::stringstream ss(line); std::string cell; while (std::getline(ss, cell, ',')) { row.push_back(cell); } data.push_back(row);}return data;
}
这段代码将CSV内容读入二维字符串向量,方便后续处理。
立即学习“C++免费学习笔记(深入)”;
处理带引号的字段
实际CSV中,包含逗号的字段常被双引号包围,例如:"Smith, John"。上述简单分割会出错。改进方法是使用完整的CSV解析逻辑,或借助状态机判断是否在引号内。
简化处理方式:先提取完整字段,再去除首尾空格和引号。
可以添加一个清理函数:
std::string trim(const std::string& str) { size_t start = str.find_first_not_of(" t""); size_t end = str.find_last_not_of(" t""); if (start == std::string::npos) return ""; return str.substr(start, end - start + 1);}
在插入cell前调用trim(cell)可提升数据整洁度。
解析数值类型数据
若CSV中包含数字,可用std::stod或std::stoi转换字符串。
例如将某列转为double:
double value = std::stod(data[rowIndex][colIndex]);
注意加入异常处理以防转换失败:
try { double value = std::stod(cell);} catch (const std::invalid_argument&) { // 处理无法转换的情况}
完整使用示例
读取文件并打印所有内容:
int main() { auto csvData = readCSV("data.csv");for (const auto& row : csvData) { for (const auto& cell : row) { std::cout << "[" << cell << "] "; } std::cout << "n";}return 0;
}
基本上就这些。对于简单场景,这种实现足够高效且易于理解。复杂需求(如嵌套引号、换行字段)建议使用专用库如fast-cpp-csv-parser。自己实现时注意边界情况,确保程序健壮性。
以上就是C++如何读取CSV文件数据_C++解析逗号分隔数据的实现的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1486878.html
微信扫一扫
支付宝扫一扫