奥本海龟 发表于 2023-3-26 23:21:29

C语言可以导入EXCEL某部分数据吗?如何实现?

1.现有两组数据,分别占据EXCEL两列,
2.其中一列作为输入,另一列作为输出
3.如何不用手打,将数据导入C语言数组{:5_96:}

dolly_yos2 发表于 2023-3-26 23:31:52

看看 libxls/OpenXLSX 之类的库?

小甲鱼的二师兄 发表于 2023-3-31 01:05:28

可以通过使用C语言提供的COM接口来实现从Excel中读取某部分数据。

具体来说,需要使用COM API来初始化Excel应用程序、打开指定的工作簿、选择要读取的单元格并读取其值。

以下是一个简单的示例代码,可以读取Excel中A1单元格的值:

#include <windows.h>
#include <ole2.h>

int main()
{
    HRESULT hr;
    IDispatch *pXL = NULL, *pBooks = NULL, *pBook = NULL, *pSheet = NULL;
    VARIANT result;

    // 初始化COM库
    CoInitialize(NULL);

    // 创建Excel应用程序对象
    hr = CoCreateInstance(&CLSID_Application, NULL, CLSCTX_SERVER, &IID_IDispatch, (void**)&pXL);
   
    // 打开工作簿
    hr = pXL->lpVtbl->get_Workbooks(pXL, &pBooks);
    hr = pBooks->lpVtbl->Open(pBooks, L"test.xlsx", 0, VARIANT_FALSE, VARIANT_FALSE, VARIANT_FALSE, VARIANT_FALSE, VARIANT_FALSE, VARIANT_FALSE, VARIANT_FALSE, VARIANT_FALSE, VARIANT_FALSE, VARIANT_FALSE, &pBook);

    // 选择单元格并读取其值
    hr = pBook->lpVtbl->get_ActiveSheet(pBook, &pSheet);
    hr = pSheet->lpVtbl->Range(pSheet, L"A1", &result);
    printf("A1=%s\n", result.bstrVal);

    // 释放COM对象
    if (pSheet) pSheet->lpVtbl->Release(pSheet);
    if (pBook) pBook->lpVtbl->Release(pBook);
    if (pBooks) pBooks->lpVtbl->Release(pBooks);
    if (pXL) pXL->lpVtbl->Release(pXL);

    // 清理COM库
    CoUninitialize();

    return 0;
}
需要注意的是,需要在代码中引入Windows头文件windows.h和ole2.h,并链接COM库。

另外,上面的示例代码仅能够读取一个单元格的值,如果要读取多个单元格则需要使用循环遍历每个单元格并逐个读取其值。

奥本海龟 发表于 2023-4-11 20:49:03

小甲鱼的二师兄 发表于 2023-3-31 01:05
可以通过使用C语言提供的COM接口来实现从Excel中读取某部分数据。

具体来说,需要使用COM API来初始化Ex ...

谢谢
页: [1]
查看完整版本: C语言可以导入EXCEL某部分数据吗?如何实现?