C/C++读写csv文件

C/C++读写csv文件

实现用C++读取.csv文件,并存到STL中
.csv文件即将表格数据转换为用分隔字符分隔的值(也可以不是逗号)

简单的demo

#include <fstream>
#include <string>
#include <sstream>

int main(){
    vector<vector<int>> user_arr;
    ifstream fp("xxx/user_data.csv"); //定义声明一个ifstream对象,指定文件路径
    string line;
    getline(fp,line); //跳过列名,第一行不做处理
    while (getline(fp,line)){ //循环读取每行数据
        vector<int> data_line;
        string number;
        istringstream readstr(line); //string数据流化
        //将一行数据按','分割
        for(int j = 0;j < 11;j++){ //可根据数据的实际情况取循环获取
            getline(readstr,number,','); //循环读取数据
            data_line.push_back(atoi(number.c_str())); //字符串传int
        }
        user_arr.push_back(data_line); //插入到vector中
    }
    return 0;
}

补充:
将字符串类型数据转换成 int 类型需要先使用 .c_str() 转成 const char* 类型,再用 atoi() 转成 int ,如果转为浮点型则 atof() ,long 型则 atol() 等等。
在这里插入图片描述
在这里插入图片描述

示例2,csv数据读取

#include <iostream>
#include <string>
#include <vector>
#include <fstream>
#include <sstream>
 
using namespace std;
 
 
int main()
{
	// 写文件
	ofstream outFile;
	outFile.open("data.csv", ios::out); // 打开模式可省略
	outFile << "name" << ',' << "age" << ',' << "hobby" << endl;
	outFile << "Mike" << ',' << 18 << ',' << "paiting" << endl;
	outFile << "Tom" << ',' << 25 << ',' << "football" << endl;
	outFile << "Jack" << ',' << 21 << ',' << "music" << endl;
	outFile.close();
 
	// 读文件
	ifstream inFile("data.csv", ios::in);
	string lineStr;
	vector<vector<string>> strArray;
	while (getline(inFile, lineStr))
	{
		// 打印整行字符串
		cout << lineStr << endl;
		// 存成二维表结构
		stringstream ss(lineStr);
		string str;
		vector<string> lineArray;
		// 按照逗号分隔
		while (getline(ss, str, ','))
			lineArray.push_back(str);
		strArray.push_back(lineArray);
	}
	
	getchar();
	return 0;
}

在这里插入图片描述

示例3 csv数据保存创建文件

#include <iostream>
#include <fstream>
#include <iomanip>
#include <sstream>
#include <string>
using namespace std;

void main()
{
    ofstream outFile("Data.csv", ios::out);
    //ios::out:如果没有文件,那么生成空文件;如果有文件,清空文件
    if (!outFile)
    {
        cout << "打开文件失败!" << endl;
        exit(1);
    }
    //写入3行数据
    for (int i = 0; i < 3; i++)
    {
        outFile << 12 << ",";
        outFile << 13 << ",";
        outFile << 14 << ",";
        outFile << "NaN" << endl;
    }
    outFile.close();
    cout << "写入数据完成" << endl;
}

在这里插入图片描述

#include <iterator>
#include <iostream>
#include <fstream>
#include <sstream>
#include <vector>
#include <string>

class CSVRow
{
    public:
        std::string const& operator[](std::size_t index) const
        {
            return m_data[index];
        }
        std::size_t size() const
        {
            return m_data.size();
        }
        void readNextRow(std::istream& str)
        {
            std::string         line;
            std::getline(str, line);

            std::stringstream   lineStream(line);
            std::string         cell;

            m_data.clear();
            while(std::getline(lineStream, cell, ','))
            {
                m_data.push_back(cell);
            }
            // This checks for a trailing comma with no data after it.
            if (!lineStream && cell.empty())
            {
                // If there was a trailing comma then add an empty element.
                m_data.push_back("");
            }
        }
    private:
        std::vector<std::string>    m_data;
};

std::istream& operator>>(std::istream& str, CSVRow& data)
{
    data.readNextRow(str);
    return str;
}  
int main()
{
    std::ifstream       file("plop.csv");

    CSVRow              row;
    while(file >> row)
    {
        std::cout <<"4th Element(" << row[3] <<")
";
    }
}
  • 11
    点赞
  • 38
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
C++读写csv文件,可以使用STL库中的fstream和sstream。具体步骤如下: 1. 包含头文件: ```c++ #include <fstream> #include <sstream> #include <iostream> #include <string> #include <vector> ``` 2. 定义读取csv文件的函数: ```c++ // 读取csv文件 std::vector<std::vector<std::string>> readCsv(std::string filename) { std::vector<std::vector<std::string>> data; // 存储csv文件中的数据 std::ifstream file(filename); // 打开csv文件 std::string line; // 存储每行数据的字符串 while (std::getline(file, line)) { // 逐行读取csv文件 std::vector<std::string> row; // 存储每行数据的向量 std::stringstream ss(line); // 将每行数据的字符串转换为流 std::string cell; // 存储每个单元格的字符串 while (std::getline(ss, cell, ',')) { // 逐个单元格读取每行数据 row.push_back(cell); // 将单元格的字符串添加到每行数据的向量中 } data.push_back(row); // 将每行数据的向量添加到存储csv文件数据的向量中 } return data; // 返回存储csv文件数据的向量 } ``` 3. 定义写入csv文件的函数: ```c++ // 写入csv文件 void writeCsv(std::string filename, std::vector<std::vector<std::string>> data) { std::ofstream file(filename); // 创建csv文件 for (auto row : data) { // 逐行写入csv文件 for (auto cell : row) { // 逐个单元格写入每行数据 file << cell << ','; // 将单元格的字符串写入csv文件,并添加逗号分隔符 } file << std::endl; // 每行数据写入完成后,添加换行符 } file.close(); // 关闭csv文件 } ``` 4. 调用读取和写入csv文件的函数: ```c++ int main() { std::string filename = "data.csv"; // csv文件路径 std::vector<std::vector<std::string>> data = readCsv(filename); // 读取csv文件 writeCsv("new_data.csv", data); // 将读取csv文件数据写入新的csv文件 return 0; } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值