C++怎么实现将数据写入Excel工作表

免费教程   2024年05月04日 17:22  

今天小编给大家分享一下C++怎么实现将数据写入Excel工作表的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

安装Spire.XLS for C++

有两种方法可以将 Spire.XLS for C++ 集成到您的应用程序中。一种方法是通过NuGet安装它,另一种方法是从我们的网站下载包并将库复制到您的程序中。通过 NuGet 安装更简单,更推荐使用。您可以通过访问以下链接找到更多详细信息。

在 C++ 应用程序中集成 Spire.XLS for C++

在 C++ 中将文本或数字值写入单元格

Spire.XLS for C++ 提供了Workbook类和Worksheet类,分别表示 文档和工作表。 用户可以使用Worksheet->GetRange(int row, int column)方法访问特定的单元格。然后,使用CellRange->SetText()或CellRange->SetNumberValue() 方法为单元格分配一个文本值或数字值。以下是详细步骤:

创建一个Workbook对象。

使用Workbook->GetWorksheets()->Get()方法获取第一个工作表。

使用Worksheet->GetRange(int row, int column)方法获取特定单元格。

使用CellRange->SetText()或CellRange->SetNumberValue()方法将文本值或数字值添加到指定的单元格。

使用Workbook->SaveToFile()方法将工作簿保存到 Excel 文件。

完整代码

C++

#include"Spire.Xls.o.h";usingnamespaceSpire::Xls;intmain(){//指定输出文件路径和名称std::wstringoutputPath=L"输出\\";std::wstringoutputFile=outputPath+L"将单个值写入单元格.xlsx";//创建一个Workbook对象Workbook*workbook=newWorkbook();//获取第一个工作表Worksheet*sheet=workbook->GetWorksheets()->Get(0);//将文本和数字写入指定的单元格sheet->GetRange(1,1)->SetText(L"名字");sheet->GetRange(1,2)->SetText(L"年龄");sheet->GetRange(1,3)->SetText(L"部门");sheet->GetRange(1,4)->SetText(L"入职日期");sheet->GetRange(1,1)->SetText(L"名字");sheet->GetRange(2,1)->SetText(L"谢殊");sheet->GetRange(2,2)->SetNumberValue(29);sheet->GetRange(2,3)->SetText(L"市场部");sheet->GetRange(2,4)->SetText(L"2018-02-26");sheet->GetRange(3,1)->SetText(L"李强");sheet->GetRange(3,2)->SetNumberValue(30);sheet->GetRange(3,3)->SetText(L"人力资源部");sheet->GetRange(3,4)->SetText(L"2017-07-13");sheet->GetRange(4,1)->SetText(L"高阳");sheet->GetRange(4,2)->SetNumberValue(35);sheet->GetRange(4,3)->SetText(L"策划部");sheet->GetRange(4,4)->SetText(L"2015-04-01");//自动调整列宽sheet->GetAllocatedRange()->AutoFitColumns();//将样式应用于第一行CellStyle*style=workbook->GetStyles()->Add(L"newStyle");style->GetFont()->SetIsBold(true);sheet->GetRange(1,1,1,4)->SetStyle(style);//保存文件workbook->SaveToFile(outputFile.c_str(),ExcelVersion::Version2016);workbook->Dispose();}效果图在 C++ 中将数组写入指定的单元格范围

Spire.XLS for C++ 提供了Worksheet->InsertArray()方法,它允许程序员将向量写入工作表的指定单元格范围。在将数组写入工作表之前,您需要将它们转换为向量。将数组写入工作表的步骤如下:

创建一个Workbook对象。

使用Workbook->GetWorksheets()->Get()方法获取第一个工作表。

创建一个数组并将其转换为一个向量或多个向量。

使用Worksheet->InsertArray()方法将向量插入工作表。

使用Workbook->SaveToFile()方法将工作簿保存到 Excel 文件。

完整代码

C++

#include"Spire.Xls.o.h";usingnamespaceSpire::Xls;usingnamespacestd;intmain(){//指定输出文件路径和名称wstringoutputPath=L"输出\\";wstringoutputFile=outputPath+L"将数组写入指定的单元格范围.xlsx";//创建一个Workbook对象Workbook*workbook=newWorkbook();//获取第一个工作表Worksheet*sheet=workbook->GetWorksheets()->Get(0);//创建一维数组wstringoneDimensionalArray[6]={L"一月",L"二月",L"三月",L"四月",L"五月",L"六月"};//将数组转换为向量vector<LPCWSTR>vec;for(size_ti=0;i<sizeof(oneDimensionalArray)/sizeof(oneDimensionalArray[0]);i++){vec.push_back(oneDimensionalArray[i].c_str());}//将向量插入工作表sheet->InsertArray(vec,1,1,false);//创建一个二维数组wstringtwoDimensionalArray[4][5]={{L"姓名",L"年龄",L"性别",L"部门.",L"联系方式."},{L"李刚",L"25",L"男",L"广告部",L"835256"},{L"刘兴桐",L"24",L"女",L"运营策划部",L"835583"},{L"陈海波",L"26",L"男",L"销售部",L"834176"}};//获取行号和列号introwNum=sizeof(twoDimensionalArray)/sizeof(twoDimensionalArray[0]);intcolumnNum=sizeof(twoDimensionalArray[0])/sizeof(twoDimensionalArray[0][0]);//将二维数组拆分为多个一维向量for(size_ti=0;i<rowNum;i++){vector<LPCWSTR>vec_temp;for(size_tj=0;j<columnNum;j++){vec_temp.push_back(twoDimensionalArray[i][j].c_str());}//将向量插入工作表sheet->InsertArray(vec_temp,4+i,1,false);}//自动调整列宽sheet->GetAllocatedRange()->AutoFitColumns();//将样式应用于第一行CellStyle*style=workbook->GetStyles()->Add(L"newStyle");style->GetFont()->SetIsBold(true);sheet->GetRange(1,1,1,6)->SetStyle(style);sheet->GetRange(4,1,4,5)->SetStyle(style);//保存文件workbook->SaveToFile(outputFile.c_str(),ExcelVersion::Version2016);workbook->Dispose();}效果图

以上就是“C++怎么实现将数据写入Excel工作表”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注行业资讯频道。

域名注册
购买VPS主机

您或许对下面这些文章有兴趣:                    本月吐槽辛苦排行榜

看贴要回贴有N种理由!看帖不回贴的后果你懂得的!


评论内容 (*必填):
(Ctrl + Enter提交)   

部落快速搜索栏

各类专题梳理

网站导航栏

X
返回顶部