溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

C++怎么實(shí)現(xiàn)將數(shù)據(jù)寫入Excel工作表

發(fā)布時(shí)間:2023-03-11 10:51:16 來源:億速云 閱讀:130 作者:iii 欄目:開發(fā)技術(shù)

今天小編給大家分享一下C++怎么實(shí)現(xiàn)將數(shù)據(jù)寫入Excel工作表的相關(guān)知識(shí)點(diǎn),內(nèi)容詳細(xì),邏輯清晰,相信大部分人都還太了解這方面的知識(shí),所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。

安裝Spire.XLS for C++

有兩種方法可以將 Spire.XLS for C++ 集成到您的應(yīng)用程序中。一種方法是通過 NuGet 安裝它,另一種方法是從我們的網(wǎng)站下載包并將庫復(fù)制到您的程序中。通過 NuGet 安裝更簡(jiǎn)單,更推薦使用。您可以通過訪問以下鏈接找到更多詳細(xì)信息。

在 C++ 應(yīng)用程序中集成 Spire.XLS for C++

在 C++ 中將文本或數(shù)字值寫入單元格

Spire.XLS for C++ 提供了 Workbook 類和 Worksheet 類,分別表示 Excel 文檔和工作表。 用戶可以使用 Worksheet->GetRange(int row, int column) 方法訪問特定的單元格。然后,使用 CellRange->SetText() 或 CellRange->SetNumberValue() 方法為單元格分配一個(gè)文本值或數(shù)字值。以下是詳細(xì)步驟:

  • 創(chuàng)建一個(gè)Workbook對(duì)象。

  • 使用 Workbook->GetWorksheets()->Get() 方法獲取第一個(gè)工作表。

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

  • 使用 CellRange->SetText() 或 CellRange->SetNumberValue() 方法將文本值或數(shù)字值添加到指定的單元格。

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

完整代碼

C++

#include "Spire.Xls.o.h";

using namespace Spire::Xls;

int main() {

    //指定輸出文件路徑和名稱
    std::wstring outputPath = L"輸出\\";
    std::wstring outputFile = outputPath + L"將單個(gè)值寫入單元格.xlsx";

    //創(chuàng)建一個(gè)Workbook對(duì)象
    Workbook* workbook = new Workbook();

    //獲取第一個(gè)工作表
    Worksheet* sheet = workbook->GetWorksheets()->Get(0);

    //將文本和數(shù)字寫入指定的單元格
    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"市場(chǎng)部");
    sheet->GetRange(2, 4)->SetText(L"2018-02-26");
    sheet->GetRange(3, 1)->SetText(L"李強(qiáng)");
    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");

    //自動(dòng)調(diào)整列寬
    sheet->GetAllocatedRange()->AutoFitColumns();

    //將樣式應(yīng)用于第一行
    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++怎么實(shí)現(xiàn)將數(shù)據(jù)寫入Excel工作表

在 C++ 中將數(shù)組寫入指定的單元格范圍

Spire.XLS for C++ 提供了 Worksheet->InsertArray() 方法,它允許程序員將向量寫入工作表的指定單元格范圍。在將數(shù)組寫入工作表之前,您需要將它們轉(zhuǎn)換為向量。將數(shù)組寫入工作表的步驟如下:

  • 創(chuàng)建一個(gè)Workbook對(duì)象。

  • 使用 Workbook->GetWorksheets()->Get() 方法獲取第一個(gè)工作表。

  • 創(chuàng)建一個(gè)數(shù)組并將其轉(zhuǎn)換為一個(gè)向量或多個(gè)向量。

  • 使用 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"將數(shù)組寫入指定的單元格范圍.xlsx";

    //創(chuàng)建一個(gè)Workbook對(duì)象
    Workbook* workbook = new Workbook();

    //獲取第一個(gè)工作表
    Worksheet* sheet = workbook->GetWorksheets()->Get(0);

    //創(chuàng)建一維數(shù)組
    wstring oneDimensionalArray[6] = { L"一月", L"二月", L"三月", L"四月", L"五月", L"六月" };

    //將數(shù)組轉(zhuǎn)換為向量
    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);

    //創(chuàng)建一個(gè)二維數(shù)組
    wstring twoDimensionalArray[4][5] = {
        {L"姓名", L"年齡", L"性別", L"部門.", L"聯(lián)系方式."},
        {L"李剛", L"25", L"男", L"廣告部", L"835256"},
        {L"劉興桐", L"24", L"女", L"運(yùn)營策劃部", L"835583"},
        {L"陳海波", L"26", L"男", L"銷售部", L"834176"}
    };

    //獲取行號(hào)和列號(hào)
    int rowNum = sizeof(twoDimensionalArray) / sizeof(twoDimensionalArray[0]);
    int columnNum = sizeof(twoDimensionalArray[0]) / sizeof(twoDimensionalArray[0][0]);

    //將二維數(shù)組拆分為多個(gè)一維向量
    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);
    }

    //自動(dòng)調(diào)整列寬
    sheet->GetAllocatedRange()->AutoFitColumns();

    //將樣式應(yīng)用于第一行
    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++怎么實(shí)現(xiàn)將數(shù)據(jù)寫入Excel工作表

以上就是“C++怎么實(shí)現(xiàn)將數(shù)據(jù)寫入Excel工作表”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會(huì)為大家更新不同的知識(shí),如果還想學(xué)習(xí)更多的知識(shí),請(qǐng)關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI