鱼C论坛

 找回密码
 立即注册
查看: 1577|回复: 3

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

[复制链接]
发表于 2023-3-26 23:21:29 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
1.现有两组数据,分别占据EXCEL两列,
2.其中一列作为输入,另一列作为输出
3.如何不用手打,将数据导入C语言数组
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-3-26 23:31:52 From FishC Mobile | 显示全部楼层
看看 libxls/OpenXLSX 之类的库?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 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库。

另外,上面的示例代码仅能够读取一个单元格的值,如果要读取多个单元格则需要使用循环遍历每个单元格并逐个读取其值。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2023-4-11 20:49:03 | 显示全部楼层
小甲鱼的二师兄 发表于 2023-3-31 01:05
可以通过使用C语言提供的COM接口来实现从Excel中读取某部分数据。

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

谢谢
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-18 01:28

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表