c++调用excel 修改图例类型的com接口,提示内存访问冲突

我使用C++ 的方式调用excel的com接口, 在新增表格的时候会提示访问冲突,这个为什么呢 ?

#include "stdafx.h"
#include <atlcomcli.h>

int _tmain(int argc, _TCHAR* argv[])
{
    CoInitialize(NULL);

    _ApplicationPtr pExcelApp;
    HRESULT hr = pExcelApp.CreateInstance(__uuidof(Excel::Application));

    if(SUCCEEDED(hr))
    {
        pExcelApp->put_Visible(0, VARIANT_FALSE);
        _WorkbookPtr pWorkbook = pExcelApp->Workbooks->Open(_T("C:\\Users\\pc\\Desktop\\2.xlsx"));
        if(pWorkbook)
        {
            SheetsPtr sheets = pWorkbook->GetSheets();
            _WorksheetPtr wSheet = (_WorksheetPtr)sheets->GetItem(1);

            ChartObjectsPtr chartObjects = (ChartObjectsPtr)wSheet->ChartObjects(vtMissing);
            ChartObjectPtr myChart = chartObjects->Add(100, 200, 400, 300);
            
            _Chart* chart = myChart->GetChart();
            chart->PutChartType(Excel::XlChartType::xlLine);    //代码运行到此处会提示访问冲突 

            pWorkbook->Close();
            pExcelApp->Quit();
        }
    }
    ::CoUninitialize();
    return 0;
}

img

检查一下指针哇~

不知道你这个问题是否已经解决, 如果还没有解决的话:
  • 看下这篇博客,也许你就懂了,链接:C++程序打开EXCEL2010失败,提示:远程过程调用失败
  • 除此之外, 这篇博客: C++处理EXCEL数据中的          3:获取多个列表,打开工作表 部分也许能够解决你的问题, 你可以仔细阅读以下内容或跳转源博客中阅读:
            //关联所有工作列表
            m_sheets.AttachDispatch(m_book.get_Worksheets(),true);
             
            //打开工作列表
            m_sheet = m_sheet.get_Item(COleVariant("sheet1"));

如果你已经解决了该问题, 非常希望你能够分享一下解决方案, 写成博客, 将相关链接放在评论区, 以帮助更多的人 ^-^