gpt4 book ai didi

如何通过C++将数据写入Excel工作表

转载 作者:我是一只小鸟 更新时间:2023-03-10 22:31:47 29 4
gpt4 key购买 nike

直观的界面、出色的计算功能和图表工具,使Excel成为最流行的个人计算机数据处理软件。在独立的数据包含的信息量太少,而过多的数据又难以理清头绪时,制作成表格是数据管理的最有效手段之一。这样不仅可以方便整理数据,还可以方便我们查找和应用数据。后期我们还可以对具有相似表格框架,相同性质的数据进行合并汇总工作。在本文中,您将学习如何使用 Spire.XLS for C++ 创建 Excel 文档 ,以及如何 将数据写入 Excel 工作表 .

  • 在 C++ 中将文本或数字值写入单元格
  • 在 C++ 中将数组写入指定的单元格范围

安装Spire.XLS for C++

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

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

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

Spire.XLS for C++ 提供了 Workbook 类和 Worksheet 类,分别表示 Excel 文档和工作表。 用户可以使用 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
                          
                          
                            "
                          
                          
                            ;


                          
                          
                            using
                          
                          
                            namespace
                          
                          
                             Spire::Xls;


                          
                          
                            int
                          
                          
                             main() {

    
                          
                          
                            //
                          
                          
                            指定输出文件路径和名称
                          
                          
    std::wstring outputPath = L
                          
                            "
                          
                          
                            输出\\
                          
                          
                            "
                          
                          
                            ;
    std::wstring outputFile 
                          
                          = outputPath + L
                          
                            "
                          
                          
                            将单个值写入单元格.xlsx
                          
                          
                            "
                          
                          
                            ;

    
                          
                          
                            //
                          
                          
                            创建一个Workbook对象
                          
                          
    Workbook* workbook = 
                          
                            new
                          
                          
                             Workbook();

    
                          
                          
                            //
                          
                          
                            获取第一个工作表
                          
                          
    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
                          
                          
                            "
                          
                          
                            ;


                          
                          
                            using
                          
                          
                            namespace
                          
                          
                             Spire::Xls;

                          
                          
                            using
                          
                          
                            namespace
                          
                          
                             std;


                          
                          
                            int
                          
                          
                             main() {

    
                          
                          
                            //
                          
                          
                            指定输出文件路径和名称
                          
                          
    wstring outputPath = L
                          
                            "
                          
                          
                            输出\\
                          
                          
                            "
                          
                          
                            ;
    wstring outputFile 
                          
                          = outputPath + L
                          
                            "
                          
                          
                            将数组写入指定的单元格范围.xlsx
                          
                          
                            "
                          
                          
                            ;

    
                          
                          
                            //
                          
                          
                            创建一个Workbook对象
                          
                          
    Workbook* workbook = 
                          
                            new
                          
                          
                             Workbook();

    
                          
                          
                            //
                          
                          
                            获取第一个工作表
                          
                          
    Worksheet* sheet = workbook->GetWorksheets()->Get(
                          
                            0
                          
                          
                            );

    
                          
                          
                            //
                          
                          
                            创建一维数组
                          
                          
    wstring oneDimensionalArray[
                          
                            6
                          
                          ] = { L
                          
                            "
                          
                          
                            一月
                          
                          
                            "
                          
                          , L
                          
                            "
                          
                          
                            二月
                          
                          
                            "
                          
                          , L
                          
                            "
                          
                          
                            三月
                          
                          
                            "
                          
                          , L
                          
                            "
                          
                          
                            四月
                          
                          
                            "
                          
                          , L
                          
                            "
                          
                          
                            五月
                          
                          
                            "
                          
                          , L
                          
                            "
                          
                          
                            六月
                          
                          
                            "
                          
                          
                             };

    
                          
                          
                            //
                          
                          
                            将数组转换为向量
                          
                          
    vector<LPCWSTR>
                          
                             vec;
    
                          
                          
                            for
                          
                           (size_t i = 
                          
                            0
                          
                          ; i < 
                          
                            sizeof
                          
                          (oneDimensionalArray) / 
                          
                            sizeof
                          
                          (oneDimensionalArray[
                          
                            0
                          
                          ]); i++
                          
                            )
    {
        vec.push_back(oneDimensionalArray[i].c_str());
    }

    
                          
                          
                            //
                          
                          
                            将向量插入工作表
                          
                          
    sheet->InsertArray(vec, 
                          
                            1
                          
                          , 
                          
                            1
                          
                          , 
                          
                            false
                          
                          
                            );

    
                          
                          
                            //
                          
                          
                            创建一个二维数组
                          
                          
    wstring twoDimensionalArray[
                          
                            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
                          
                          
                            "
                          
                          
                            }
    };

    
                          
                          
                            //
                          
                          
                            获取行号和列号
                          
                          
                            int
                          
                           rowNum = 
                          
                            sizeof
                          
                          (twoDimensionalArray) / 
                          
                            sizeof
                          
                          (twoDimensionalArray[
                          
                            0
                          
                          
                            ]);
    
                          
                          
                            int
                          
                           columnNum = 
                          
                            sizeof
                          
                          (twoDimensionalArray[
                          
                            0
                          
                          ]) / 
                          
                            sizeof
                          
                          (twoDimensionalArray[
                          
                            0
                          
                          ][
                          
                            0
                          
                          
                            ]);

    
                          
                          
                            //
                          
                          
                            将二维数组拆分为多个一维向量
                          
                          
                            for
                          
                           (size_t i = 
                          
                            0
                          
                          ; i < rowNum; i++
                          
                            )
    {
        vector
                          
                          <LPCWSTR>
                          
                             vec_temp;
        
                          
                          
                            for
                          
                           (size_t j = 
                          
                            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工作表的文章就讲到这里了,如果你想了解更多关于如何通过C++将数据写入Excel工作表的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com