亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C++ > 正文

C++通過COM接口操作PPT

2020-01-26 14:08:54
字體:
來源:轉載
供稿:網友

一、 背景說明

在VS環境下,開發C++代碼操作PPT,支持對PPT模板的修改。包括修改文本標簽、圖表、表格。滿足大多數軟件生成PPT報告的要求,先手工創建好PPT模板,在程序中修改模板數據。

二、 開發環境構建

通過VS2012的Class Wizard創建PowerPoint和Excel的COM接口;由于需要操作PPT中的圖表,而圖表的數據使用Excel存儲的,需要修改圖表的數據就得生成Excel的COM接口。

1.1 進入類向導

1.2 添加PowerPoint COM接口

1.3 添加Excel COM接口

選中所有的COM接口,生成接口文件。

三、 定義PPT文件基礎操作函數(頭文件略)

3.1 定義PPT應用基礎對象

class CPPTObject{public:  CApplication m_PPTApp;  CSlides m_Slides;  CSlide m_curSlide;  CPresentation m_Presentaion;};

3.2 啟動PowerPoint軟件,調用COM接口需要安裝Office

// 創建PPT應用,啟動powerpoint程序。bool CPPTUtil::CreatePPTApplication(){  COleException exception;  LPCSTR str = "Powerpoint.Application";  if(!m_pPPTObject->m_PPTApp.CreateDispatch(str, &exception))  {    AfxMessageBox(exception.m_sc, MB_SETFOREGROUND);    return false;  }  m_pPPTObject->m_PPTApp.put_Visible(true);  return true;}

3.3 打開PPT模板文件。修改PPT內容前,先打開PPT。

// 打開模板ppt。bool CPPTUtil::OpenPPT(const std::string& pptPath){  CPresentations presentations = m_pPPTObject->m_PPTApp.get_Presentations();  m_pPPTObject->m_Presentaion = presentations.Open(CString(pptPath.c_str()), 0, 0, 1);  m_pPPTObject->m_Slides = m_pPPTObject->m_Presentaion.get_Slides();  return true;}

3.4 保存PPT文件內容,關閉文件,退出PowerPoint程序。

// 關閉PPT,保存數據關閉。bool CPPTUtil::ClosePPT(){  m_pPPTObject->m_Presentaion.Save();  m_pPPTObject->m_Presentaion.Close();  m_pPPTObject->m_PPTApp.Quit();  return true;}

3.5 選中具體的PPT幻燈片。

// 選中PPT指定索引的幻燈片。bool CPPTUtil::SelectSlide(long slideIndex){  if (slideIndex > m_pPPTObject->m_Slides.get_Count())  {    return false;  }  m_pPPTObject->m_curSlide = m_pPPTObject->m_Slides.Range(COleVariant(slideIndex));  return true;}

四、 修改文本編輯框函數

// 修改文本框bool CPPTUtil::ModifyTextBox(const std::string& boxName, const std::string& strValue){  CShapes shapes = m_pPPTObject->m_curSlide.get_Shapes();  for(long i = 1; i <= shapes.get_Count(); ++i)  {    CShape shape(shapes.Item(COleVariant(i)));    CString name = shape.get_Name();    if(shape.get_Type() == (long)Office::msoTextBox      && name.Compare(CString(boxName.c_str())) == 0)     {      CTextFrame textFrame = shape.get_TextFrame();      CTextRange textRange = textFrame.get_TextRange();      CString txt = textRange.get_Text();      textRange.put_Text(strValue.c_str());    }  }  return true;}

boxName對應于PPT中的Shape Name。這個Shape Name貌似在PowerPoint中沒有地方能看到,也沒有辦法修改。只能在調試時記錄下來。

五、 修改PPT中的圖表函數。先在PPT中定義圖表模板,通過COM接口修改圖表數據。

5.1 定義圖表數據結構。圖表的數據都是用Excel存儲的。

5.1.1 定義單元格數據結構

CCellDataCom::CCellDataCom(const CellValueType valueType, const std::string& strValue,       const int iRow, const int iCol){  m_ValueType = valueType;  m_strValue = strValue;  m_strPos = indexToString(iRow, iCol);}// 獲取單元格值類型CellValueType CCellDataCom::getValueType(){  return m_ValueType;}// 獲取字符串類型值const std::string& CCellDataCom::getStringValue(){  return m_strValue;}// 獲取整型值long CCellDataCom::getLongValue(){  return atol(m_strValue.c_str());}// 獲取浮點類型值double CCellDataCom::getDoubleValue(){  return atof(m_strValue.c_str());}// 獲取單元格位置名稱const std::string& CCellDataCom::getPos(){  return m_strPos;}// 將單元格坐標轉換名稱字符串CString CCellDataCom::indexToString( int row, int col )  {    CString strResult;   if( col > 26 )    {      strResult.Format(_T("%c%c%d"),'A' + (col-1)/26-1,'A' + (col-1)%26,row);   }    else    {    strResult.Format(_T("%c%d"), 'A' + (col-1)%26,row);   }   return strResult; }  

5.1.2   定義圖表數據結構

// 插入一行記錄void CChartDataCom::insertRowData(const std::list<CCellDataCom>& lstRowData){  m_lstValue.push_back(lstRowData);}// 獲取圖表數據const std::list<std::list<CCellDataCom> >& CChartDataCom::getValue()const{  return m_lstValue;}

5.2 修改圖表數據函數

// 修改圖表bool CPPTUtil::ModifyChart(const std::string& chartName, const CChartDataCom& chartData){  CShapes shapes = m_pPPTObject->m_curSlide.get_Shapes();  for(long i = 1; i <= shapes.get_Count(); ++i)  {    CShape shape(shapes.Item(COleVariant(i)));    if(shape.get_Type() != (long)Office::msoChart      || chartName != std::string(shape.get_Name().GetBuffer()))    {      continue;    }    // 修改圖表數據    return ModifyChartData(shape.get_Chart(), chartData);  }  return false;}// 修改圖表數據bool CPPTUtil::ModifyChartData(CChart chart, const CChartDataCom& chartData){  // 激活圖表組件的excel數據表格,打開內嵌的excel.  CChartData chartDataModel = chart.get_ChartData();  chartDataModel.Activate();  CWorkbook workBook = chartDataModel.get_Workbook();  CWorksheets sheets = workBook.get_Worksheets();  if(sheets.get_Count() == 0)  {    return false;  }  // 獲取第一個sheet, 圖表組件的數據都在內嵌excel的第一個sheet頁。  VARIANT vaSheetIndex;  vaSheetIndex.vt = VT_I4;  vaSheetIndex.lVal = 1;  CWorksheet sheet = sheets.get_Item(vaSheetIndex);  bool bRet = true;  // 循環修改單元格的數據  const std::list<std::list<CCellDataCom> >& lstValue = chartData.getValue();  std::list<std::list<CCellDataCom> >::const_iterator iterAllData = lstValue.begin();  for(; iterAllData != lstValue.end(); ++iterAllData)  {    std::list<CCellDataCom>::const_iterator iterRowData = iterAllData->begin();    for(; iterRowData != iterAllData->end(); ++iterRowData)    {      bRet = ModifyCellData(sheet, *iterRowData);      if(bRet == false)      {        break;      }    }    if(bRet == false)    {      break;    }  }  // 關閉Excel  CApplication0 app0 = workBook.get_Application();  app0.Quit();  Sleep(2000);  return bRet;}// 修改單元格數據bool CPPTUtil::ModifyCellData(CWorksheet sheet, CCellDataCom cellData){  const std::string& cellPos = cellData.getPos();  CRange range = sheet.get_Range(COleVariant(cellPos.c_str()), COleVariant(cellPos.c_str()));  COleVariant* pOleVar = NULL;  if(cellData.getValueType() == CELL_STRING_TYPE)  {    pOleVar = new COleVariant(CString(cellData.getStringValue().c_str()));  }  else if(cellData.getValueType() == CELL_LONG_TYPE)  {    pOleVar = new COleVariant(cellData.getLongValue());  }  else if(cellData.getValueType() == CELL_DOUBLE_TYPE)  {    pOleVar = new COleVariant(cellData.getDoubleValue());  }  else  {    return false;  }  range.put_Value2(*pOleVar);  delete pOleVar;  return true;}

六、 合并多個PPT文件函數

// 合并PPTbool CPPTUtil::MergePPT(const std::string& outputPPTPath, const std::list<std::string>& lstMergePPTPath){  CApplication pptApp;  COleException exception;  // 打開PowerPoint程序  LPCSTR str = "Powerpoint.Application";  if(!pptApp.CreateDispatch(str, &exception))  {    AfxMessageBox(exception.m_sc, MB_SETFOREGROUND);    return false;  }  pptApp.put_Visible(true);  // 打開輸出文件  CPresentations presentations = pptApp.get_Presentations();  CPresentation outPresention = presentations.Open(CString(outputPPTPath.c_str()), 0, 0, 1);  // 循環打開合并文件插入PPT頁面  std::list<std::string>::const_iterator iterMergeFile = lstMergePPTPath.begin();  for(; iterMergeFile != lstMergePPTPath.end(); ++iterMergeFile)  {    CPresentation mergePresention = presentations.Open(CString(iterMergeFile->c_str()), 0, 0, 1);    CSlides mergeSlides = mergePresention.get_Slides();    int pageNum = mergeSlides.get_Count();    mergePresention.Close();    // 合并PPT頁簽    CSlides outSlides = outPresention.get_Slides();    outSlides.InsertFromFile(CString(iterMergeFile->c_str()), outSlides.get_Count(), 1, pageNum);  }  outPresention.Save();  outPresention.Close();  pptApp.Quit();  return true;}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久艳片www.17c.com| 国产成人在线一区二区| 欧美成人午夜激情在线| 96精品视频在线| 精品magnet| 91精品久久久久久久久久久久久| 国产精品国产亚洲伊人久久| 亚洲xxxx视频| 成人欧美一区二区三区在线| 国产精品www色诱视频| 国产欧美日韩丝袜精品一区| 亚洲福利在线观看| 韩国日本不卡在线| 97视频在线观看成人| 亚洲天堂男人的天堂| 亚洲男女性事视频| 国产91亚洲精品| 国产精品三级美女白浆呻吟| 国产欧美亚洲视频| 亚洲黄一区二区| 欧美日韩一区二区三区| 久久久久久久电影一区| 最近2019中文字幕一页二页| 日韩成人性视频| 黄色成人在线免费| 91亚洲永久免费精品| 国内精品视频在线| 欧美电影免费观看电视剧大全| 国产欧美日韩丝袜精品一区| 揄拍成人国产精品视频| 精品电影在线观看| 亚洲美女又黄又爽在线观看| 成人免费观看a| 国产精品日韩在线一区| 日韩欧美亚洲国产一区| 亚洲一区二区在线| 亚洲一级片在线看| 成人免费自拍视频| 国产成人高清激情视频在线观看| 国产精品99一区| 欧美电影免费观看大全| 精品久久久久久中文字幕大豆网| 国产日韩精品在线观看| 成人在线中文字幕| 国产精品444| 55夜色66夜色国产精品视频| 91精品国产91久久| 亚洲美女自拍视频| 精品毛片网大全| 7m第一福利500精品视频| 国产精品久久久久高潮| 久久99精品久久久久久琪琪| 成人免费午夜电影| 中文字幕久久久av一区| 久久久精品久久久| 久久久久久久国产| 久久精品国产综合| 欧美一级bbbbb性bbbb喷潮片| 成人免费直播live| 亚洲欧美精品suv| 国产97在线播放| 俺去亚洲欧洲欧美日韩| 国内精品400部情侣激情| 高清在线视频日韩欧美| 亚洲自拍另类欧美丝袜| 久热精品视频在线观看一区| 中文字幕精品久久久久| 日韩网站免费观看高清| 欧美一级视频免费在线观看| 2019中文字幕在线观看| 色噜噜狠狠狠综合曰曰曰| 国产偷亚洲偷欧美偷精品| 亚洲天堂一区二区三区| 国产精品pans私拍| 欧美在线视频免费观看| 狠狠躁18三区二区一区| 免费97视频在线精品国自产拍| 欧美日韩美女在线| 国产精品自拍视频| 亚洲国产精彩中文乱码av| xxx成人少妇69| 国产不卡精品视男人的天堂| 久久久www成人免费精品| 国产精品夜间视频香蕉| 亚洲人成电影在线播放| 国产99久久久欧美黑人| 69av视频在线播放| 精品久久久视频| 中文字幕欧美专区| 色偷偷av一区二区三区| 欧美久久精品一级黑人c片| 久久99国产精品久久久久久久久| 国产精品久久久久久网站| 久久久久久97| 亚洲另类激情图| 亚洲欧美日韩在线高清直播| 欧美肥老妇视频| 日韩在线视频线视频免费网站| 91精品国产91久久久久久久久| 欧美大片免费看| 91精品综合久久久久久五月天| 欧美床上激情在线观看| 欧美精品videos另类日本| 国产不卡av在线免费观看| 日韩专区在线播放| 久久99精品久久久久久琪琪| 日韩三级成人av网| 欧美成人免费一级人片100| 成人深夜直播免费观看| 91免费的视频在线播放| 2021国产精品视频| 北条麻妃99精品青青久久| 国产精品久久91| 亚洲精品女av网站| 在线观看国产精品日韩av| www.国产一区| 亚洲成年人在线播放| 自拍偷拍亚洲一区| 欧美日韩高清在线观看| 国产视频欧美视频| 亚洲视频第一页| 欧美成人精品一区二区| 成人性生交大片免费看视频直播| 日韩精品在线免费播放| 久久免费视频在线观看| 欧美高清视频在线观看| 日韩精品在线观看视频| 亚洲日本aⅴ片在线观看香蕉| 久久久之久亚州精品露出| 亚洲人成电影网站色| 亚洲电影免费观看高清完整版在线| 日韩欧美aaa| 亚洲国产精品视频在线观看| 日韩一中文字幕| 色黄久久久久久| 日韩在线视频中文字幕| 日韩在线一区二区三区免费视频| 国产精品久久久久久久久久久新郎| 亚洲系列中文字幕| 亚洲欧美日韩久久久久久| 中文字幕欧美在线| 久久久久久网址| 亚洲成人免费网站| 精品亚洲国产视频| 亚洲国产精品中文| 热re91久久精品国99热蜜臀| 亚洲精品98久久久久久中文字幕| 欧美高清理论片| 黑人巨大精品欧美一区二区三区| 97国产精品视频人人做人人爱| 亚洲国产日韩精品在线| 亚洲精品资源美女情侣酒店| 日韩久久免费视频| 国产午夜精品美女视频明星a级| 91亚洲国产成人精品性色| 国产91精品黑色丝袜高跟鞋| 欧美巨乳美女视频| 国产精品高潮呻吟久久av黑人| 欧美成人中文字幕在线| 日韩亚洲第一页| 国产精品久久久久av| 91免费人成网站在线观看18| 成人免费网站在线看| 久久精品一区中文字幕|